Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why is math.max() returning NaN on an array of integers?

I am trying to get the highest number from a simple array:

data = [4, 2, 6, 1, 3, 7, 5, 3];  alert(Math.max(data)); 

I have read that if even one of the values in the array can't be converted to number, it will return NaN, but in my case, I have double-checked with typeof to make sure they are all numbers, so what can be my problem?

like image 506
Matt Welander Avatar asked Sep 18 '15 08:09

Matt Welander


People also ask

Can you use math Max on an array?

Getting the maximum element of an array apply() to get the maximum of an array. getMaxOfArray([1, 2, 3]) is equivalent to Math. max(1, 2, 3) , but you can use getMaxOfArray() on programmatically constructed arrays. This should only be used for arrays with relatively few elements.

How do you find the maximum element in an array using Max math?

To get the index of the max value in an array: Get the max value in the array, using the Math. max() method. Call the indexOf() method on the array, passing it the max value.


1 Answers

The reason why your code doesn't work is because Math.max is expecting each parameter to be a valid number. This is indicated in the documentation as follows:

If at least one of arguments cannot be converted to a number, the result is NaN.

In your instance you are only providing 1 argument, and that 1 value is an array not a number (it doesn't go as far as checking what is in an array, it just stops at knowing it isn't a valid number).

One possible solution is to explicitly call the function by passing an array of arguments. Like so:

Math.max.apply(Math, data); 

What this effectively does is the same as if you manually specified each argument without an array:

Math.max(4, 2, 6, 1, 3, 7, 5, 3); 

And as you can see, each argument is now a valid number, so it will work as expected.

Spreading an array

You can also spread the array. This essentially treats the array as if each item is being passed as it's own argument.

Math.max(...data); 
like image 189
musefan Avatar answered Sep 21 '22 12:09

musefan