var arr = [34,13,56,88,76,21,98,76,43,54];
var temp = 0;
for(var i = 0; i < arr.length; i++) {
for(var j = 0; j< arr.length-i; j++) {
if(!(arr[j] < arr[j+1])) {
temp = arr[j + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
console.log(!(34 < 54)); //false
console.log(arr);
双重循环中的if()条件判断语句崩了,但是下面的console语句得到了false
控制台报错,第一次碰到这个问题,求大神解答

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
i = 0 是,内部j循环j从0取到arr.length-1
那么 j = arr.length-1 的时候arr[j+1]就会溢出
非常有趣的问题!
楼上说对了一点: 假设 arr.length 是 10。当 j = 9 时,你的代码会比较 a[9] 和 a[10] 的值,此时 a[9] 是个数,a[10] 是 undefined。如果你的 if 为真,那么你会交换 a[9] 和 a[10],而给 a[10] 赋值会导值 a.length 变为 11,从而循环无法终止,最终导致溢出。
那为什么换一种写法又可以呢?其实这里问题出在数字和 undefined 的比较上。你不妨试下:
45 < undefined和45 > undefined,会发现两个结果都是 false,原因在此 http://stackoverflow.com/ques... 。因此 a[j] > a[j+1] 在边界始终为 false,程序也就能正常结束了。里面那个for异步去了吧
栈溢出了,感觉你是写个冒泡排序。
var arr = [23,-34,434,234,34,434];
你这个for循环有问题了吧,当i=0的时候
这个if判断语句中arr[j+1]是不存在的
如果if为真,arr长度将无限增加,进入死循环
这逻辑判断写的也是醉人 if(!(arr[j] < arr[j+1]))
对不起我没耐心解释,我错了,谢谢举报。