首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Math.max()方法获取数组中的最大值返回NaN问题分析

今天群里边有人问到 Math.max() 方法返回 NaN 的问题,我简单举个例子,看下图: 看上去没什么问题,但为什么返回 NaN 呢?...我们先简单看一下  Math.max() 方法: Math.max() Math.max() 函数返回一组数中的最大值。...返回值: 返回给定的一组数字中的最大值。 注意:如果给定的参数中至少有一个参数无法被转换成数字,则会返回 NaN。 问题解决 仔细观察可以发现,代码中使用了 ......解构,这没问题,ES6 语法是支持这样了,会把数组解构成一组值。 但这里的问题是 array 是一个二维数组,解构完还是一个数组,而非数字,所以返回 NaN 了。...未经允许不得转载:w3h5 » Math.max()方法获取数组中的最大值返回NaN问题分析

4.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    数组的实际操作求数组中数字的最大值

    DOCTYPE html>          一维数组最大值              //一维数组初始         var num=[1,56,23,954,6,43,87,3,5,55];         function max(arr...){             var temp=arr[0];//初始化最大值默认为数组的第0号元素             //遍历出数组全部元素         for(var i=0;i<arr.length...;i++){             //用初始化的值和遍历出的值比较大于初始化值,则将遍历后值即为最大值             if(arr[i]>temp){                 temp...=arr[i];             }         }         return temp;//将比较最大值返回给temp         }                  var re

    1.8K30

    分割数组的最大值

    问题描述: 给定一个非负整数数组和一个整数 m,你需要将这个数组分成 m 个非空的连续子数组。设计一个算法使得这 m 个子数组各自和的最大值最小。...nums分割为2个子数组。...解决方案 贪心+二分 该问题是一道经典的贪心+二分的问题。 不妨设k为子数组的最大和,由题意可知存在如下结论: 若以子数组和最大值为k可以分割出m个子数组,则以k+ 1也一定能分割出m个子数组。...由该结论我们就可以对k从[max(nums), sum(nums)]区间中二分查找出满足条件的k的最小值。上式中下界max(nums)为当前数组的最大值,sum(nums)为当前数组之和。...dp[i - 1] [k - 1]为前段的最大子数组和,max(…)是为了获得最大子数组和,外面的min(…)是为选出所有分割子数组和最大值最小的那个。

    4.4K10

    Python算法与数据结构--求所有子数组的和的最大值

    题目:输入一个整形数组,数组里有正数也有负数。数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。 求所有子数组的和的最大值。要求时间复杂度为O(n)。...这个题目有多个解法,比如可以用一个二维数组存之前每个数据的和,然后在进行大小比较;但是这样时间负责度就是O(n2)了。 换个思路思考下,因为是要最大数,那么就不需要存储,只需要找最大值就可以了。...但是为了找子序列的最大和,在遇到相加为负数的情况要跳过,这块注意代码中最后一个if的注释。...基本思路:一个数一个数相加,相加后和最大数以及当前这个数对比,找出最大的;如果相加后是负数,则累加清零 代码----------- # -*- coding: utf-8 -*- """ 题目:输入一个整形数组...数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。 求所有子数组的和的最大值。要求时间复杂度为O(n)。

    1.8K20

    子数组最小乘积的最大值(前缀和 + 单调栈)

    题目 一个数组的 最小乘积 定义为这个数组中 最小值 乘以 数组的 和 。 比方说,数组 [3,2,5] (最小值是 2)的最小乘积为 2 * (3+2+5) = 2 * 10 = 20 。...给你一个正整数数组 nums ,请你返回 nums 任意 非空子数组 的最小乘积 的 最大值 。由于答案可能很大,请你返回答案对 10^9 + 7 取余 的结果。...请注意,最小乘积的最大值考虑的是取余操作 之前 的结果。 题目保证最小乘积的最大值在 不取余 的情况下可以用 64 位有符号整数 保存。 子数组 定义为一个数组的 连续 部分。...示例 2: 输入:nums = [2,3,3,1,2] 输出:18 解释:最小乘积的最大值由子数组 [3,3] (最小值是 3)得到。 3 * (3+3) = 3 * 6 = 18 。...示例 3: 输入:nums = [3,1,5,6,4,2] 输出:60 解释:最小乘积的最大值由子数组 [5,6,4] (最小值是 4)得到。

    75240

    任意子数组和的绝对值的最大值(贪心)

    一个子数组 [numsl, numsl+1, ..., numsr-1, numsr] 的 和的绝对值 为 abs(numsl + numsl+1 + ... + numsr-1 + numsr) 。...请你找出 nums 中 和的绝对值 最大的任意子数组(可能为空),并返回该 最大值 。 abs(x) 定义如下: 如果 x 是负整数,那么 abs(x) = -x 。...示例 1: 输入:nums = [1,-3,2,3,-4] 输出:5 解释:子数组 [2,3] 和的绝对值最大,为 abs(2+3) = abs(5) = 5 。...思路 子数组绝对值最大等价于子数组最大或者子数组最小。 维护子数组最大:如果当前和为正,则继续加。如果当前和为负,如果继续加等于负数加当前数字,比不上0加当前数字得到的结果大,置和为当前数字。...维护子数组最小:如果当前和为负,则继续加。如果当前和为正,如果继续加等于正数加当前数字,比不上0加当前数字得到的结果小,置和为当前数字。 每次获取最大绝对值即可。

    59710
    领券