我想知道为什么我在这里得到一个无限循环。我只是不想传递这个初始值,所以如果它们是undefined
,它们会自动计算出来。它只是为了清理我的函数调用只使用一个参数。如果我通过它们,一切运行正常,过程结束。有人可以帮忙吗?感谢
function merge(array, lower, half, upper){
//Suppressed for the sake of brevity
}
function mergeSort(array, lower, upper){
if(!lower && !upper){ //take a look here
lower = 0;
upper = array.length - 1;
}
if(lower < upper){
var half = Math.floor((lower + upper)/2);
mergeSort(array, lower, half);
mergeSort(array, half + 1, upper);
merge(array, lower, half, upper);
}
}
var array = [8, 3, 6, 4, 1, 0, 23, 12, 15, 63];
mergeSort(array); //infinite loop here
console.log(array);
答案 0 :(得分:7)
你对mergeSort
的第一次递归调用将0
作为第一个参数传递,因为你设置了它。
由于!0
也会对false
进行评估,所以你可以去..
使用undefined
运算符
typeof
if(typeof lower === 'undefined' && typeof upper === 'undefined'){ //take a look here
lower = 0;
upper = array.length - 1;
}
或者更好的是,检查arguments.length
,例如
if( arguments.length === 1 ) {
var lower = 0,
upper = array.length -1 ;
}