我无法让此代码正常工作。我已经有一段时间试图弄清楚了。当我查看控制台时,它只显示 0。我做错了什么?
这是我的代码:
var array = [3 , 6, 2, 56, 32, 5, 89, 32];
var largest= 0;
for (i=0; i<=largest;i++){
if (array>largest) {
var largest=array[i];
}
}
console.log(largest);
我无法让此代码正常工作。我已经有一段时间试图弄清楚了。当我查看控制台时,它只显示 0。我做错了什么?
这是我的代码:
var array = [3 , 6, 2, 56, 32, 5, 89, 32];
var largest= 0;
for (i=0; i<=largest;i++){
if (array>largest) {
var largest=array[i];
}
}
console.log(largest);
var arr = [3, 6, 2, 56, 32, 5, 89, 32];
var largest = arr[0];
for (var i = 0; i < arr.length; i++) {
if (largest < arr[i] ) {
largest = arr[i];
}
}
console.log(largest);
i
,否则它会成为全局变量。i < array.length
而不是i <= largest
.largest
,请使用if(largest < array[i])
而不是if(array > largest)
array
Array
是一个错误的变量名,因为它与(数组构造函数)太相似了。试试arr
吧。一个班轮:
var largest = Math.max.apply(0, array);
下面的代码是固定的,应该可以工作。问题是在这一行中if (array>largest) {
你没有提供数组的索引。通过将代码更改为此if (array[i]>largest) {
它可以工作。请注意,我在 if 语句[i]
的末尾添加了 。array
var array = [3 , 6, 2, 56, 32, 5, 89, 32];
var largest= 0;
for (i=0; i<=largest;i++){
if (array[i]>largest) {
var largest=array[i];
}
}
console.log(largest);
只有一行:)
var array = [3 , 6, 2, 56, 32, 5, 89, 32],
largest = array.sort((a,b)=>a-b).reverse()[0];
甚至更好
...
largest = array.sort((a,b)=>a-b)[array.length - 1];
UPD,当您在数组中添加例如 9 时,上面的所有代码都很糟糕,因为默认情况下,数字在排序中被视为字符串,有更好的版本
var array = [3 , 6, 2, 56, 32, 5, 89, 32, 9], largest;
array.sort(function(a, b) {
largest = a > b ? a: b;
});
尽管在评论中建议的性能forEach
循环更好
http://jsperf.com/array-sorting-javascript-stack
UPD2,好的,上面的代码有一些不好的部分,所以不能按预期工作。另一个尝试:
array.sort(function(a, b) {
return a - b;
});
largest = array[array.length - 1];
你有几个小错误。第一的:
if (array>largest) {
它应该是:
if ( array[i]>largest) {
第二:
for ( i = 0; i <= largest; i++) {
应该
for (i = 0; i <= array.length; i++) {
var array = [3 , 6, 2, 56, 32, 5, 89, 32];
var largest= array[0];
for (i=0; i<=largest;i++){
if (array[i]>largest) {
largest=array[i];
}
}
您的代码中有两个问题。首先,array>largest
应该是array[i]>largest
。其次,您在if
其中声明了一个新的最大变量,该变量与外部变量不同。var
从新最大值的赋值中删除。