Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8196587
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 7, 20262026-06-07T05:31:51+00:00 2026-06-07T05:31:51+00:00

Given an array $arr of the form: Array ( [0] => Array ([id] =>

  • 0

Given an array $arr of the form:

Array (
    [0] => Array ([id] => id1, ...)
    [1] => Array ([id] => id1, ...)
    [2] => Array ([id] => id2, ...)
    ...
)

Using this foreach loop:

$rowsById = [];
foreach ($arr as $row) {
    $rowsById[$row['id']][] = $row;
}

We can transform it to an array of the form (keyed by ids):

Array (
    [id1] => Array (
                 [0] => Array ([id] => id1, ...)
                 [1] => Array ([id] => id1, ...)
             )
    [id2] => Array (
                 [0] => Array ([id] => id2, ...)
             )
    ...
)

Can we do the same thing but without the foreach loop?
(That is, with some iterating function like array_walk and a callback)

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-07T05:31:52+00:00Added an answer on June 7, 2026 at 5:31 am
    $map = array();
    array_walk($arr, function($row, $i) use(&$map) { $map[$row['id']][] = $row; });
    

    From a formal point of view, this solution is a positive answer to your question.

    But, if you wanted to speed up the code, or even if you wanted cleaner code without loosing too much somewhere else, here is the surprise: this solution is definitely slower than your foreach loop (by a factor of 3 on my machine). The reason is almost certainly the function call to the anonymous function, which is absent in the foreach solution. As I already pointed out in another answer here on SO, it’s the function calls that eat up CPU time.

    This situation could be different if we could just combine simple array_ functions to obtain the same result, but the fact that ['id'] must be accessed somehow, the overhead of creating intermediate arrays, plus the fact that no array_ function is available for direct assignment to keyed bins, make this an impossible task.

    For example, this code that I posted before realizing that it was wrong (because it replaces instead of appending to the bins)

    $map = array_combine(array_map(function($a) { return $a['id']; }, $arr), $arr);
    

    runs slower than your foreach by a factor of 2.5 on my machine.

    So, at the end, the answer to your question is: “Yes, if we don’t care about processing time”.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Given following array: var arr = [undefined, undefined, 2, 5, undefined, undefined]; I'd like
This problem is taken from interviewstreet.com Given array of integers Y=y1,...,yn, we have n
Given an Array A of n subArrays Sn, how can I select the Array
Given an array with n values, for example: $arr[] = 'ABCDEFABC'; $arr[] = 'ABCDEFDEF';
Given an array like this: Array => ( [0] => 1, [1] => 2,
Given an array. How can we find sum of elements in index interval (i,
Given an array: arr = [['a', '1'], ['b','2'], ['c', '3']] Whats the best way
Given I've got an array arr of instances of a custom class My_class .
Given an array: var arr = [1,,2,5,6,,4,5,6,,]; Count how many empty values is has:
Given an Array arr of size 100000, each element 0 <= arr[i] < 100

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.