Skip to content

Latest commit

 

History

History
95 lines (69 loc) · 4.49 KB

Bonfire-Return-Largest-Numbers-in-Arrays.md

File metadata and controls

95 lines (69 loc) · 4.49 KB

Explanation:

You will get an array that contains sub arrays of numbers and you need to return an array with the largest number from each of the sub arrays.

Hint: 1

You will need to keep track of the array with the answer and the largest number of each sub-array.

Hint: 2

You can work with multidimensional arrays by Array[Index][SubIndex]

Hint: 3

Pay close attention to the timing of the storing of variables when working with loops

Spoiler Alert!

687474703a2f2f7777772e796f75726472756d2e636f6d2f796f75726472756d2f696d616765732f323030372f31302f31302f7265645f7761726e696e675f7369676e5f322e676966.gif

Solutions ahead!

Solution 1:

function largestOfFour(arr) {
  var results = [];
  for (var n = 0; n < arr.length; n++) {
    var largestNumber = 0;
    for (var sb = 0; sb < arr[n].length; sb++) {
      if (arr[n][sb] > largestNumber) {
        largestNumber = arr[n][sb];
      }
    }

    results[n] = largestNumber;
  }

  return results;
}

Code Explanation:

  • Create a variable to store the results as an array.
  • Create an outer loop to iterate through the main array.
  • Before going into the inner loop, create a variable to hold the largest number. This must be outside the inner loop.
  • Create another for loop to work with the sub-arrays.
  • Check if the element of the sub array is larger than the current largest number. If so, then save the number.
  • After the inner loop, save the largest number in the variable for the results.

Solution 2:

function largestOfFour(arr) {
  // You can do this!
  // Yes, I can. :P
  return arr.map(Function.apply.bind(Math.max, null));
}

largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]);

Code Explanation:

  • The Function.apply.bind(Math.max, null) makes a new function accepting the arr.map values i.e. the inner arrays.

Now the new function needs to find the max of the input inner array.

  • So we want to create a function that does the work of Math.max and accepts input as an array.

e.g. wouldn't be nice if the Math.max would be accepting inputs like this:
Math.max([9, 43, 20, 6]); // 43.

  • To do the work of accepting params as array, there is this Function.apply method but it invokes the context function.

i.e. Math.max.apply(null, [9, 43, 20, 6]); // 43 would invoke the Max.max method.

Here we're passing null as the context of the Function.apply method as Math.max doesn't need any context.

But that's not useful for arr.map which accepts a function value. So we create a function value using Function.bind method.

  • Since, Function.apply is a static method of Function Object, so we can call Function.prototype.bind on Function.apply i.e. Function.apply.bind.

Now we pass the context for Function.apply.bind call i.e. Math.max method as the 1st argument which would give us the functionality of Math.max method.

  • Since Function.apply method takes a context as it's 1st argument, hence, we need to pass a bogus context for Function.apply method.
    • So, we pass null as the 2nd param to Function.apply.bind which gives a context to the Math.max method.
    • Since, Math.max is independent of any context, hence, it ignores the bogus context given by Function.apply method call.

So in the end we get a function (using Function.bind method) that works like Math.max but accepts params as an array like Function.apply 😃

comprendido? 😐

NOTE: This is an advanced solution. NOT FOR BEGINNERS.

Reference:-

Credits:

If you found this page useful, you can give thanks by copying and pasting this on the main chat: Thanks @Rafase282 @abhisekp for your help with Bonfire: Return Largest Numbers in Arrays

NOTE: Please add your username only if you have added any relevant main contents to the wiki page. (Please don't remove any existing usernames.)