我正在尝试在 JavaScript 中实现二进制搜索算法。事情似乎没问题,但我的返回语句似乎返回未定义。谁能告诉我这里出了什么问题?
小提琴:http: //jsfiddle.net/2mBdL/
var a = [
1,
2,
4,
6,
1,
100,
0,
10000,
3
];
a.sort(function (a, b) {
return a - b;
});
console.log('a,', a);
function binarySearch(arr, i) {
var mid = Math.floor(arr.length / 2);
console.log(arr[mid], i);
if (arr[mid] === i) {
console.log('match', arr[mid], i);
return arr[mid];
} else if (arr[mid] < i && arr.length > 1) {
console.log('mid lower', arr[mid], i);
binarySearch(arr.splice(mid, Number.MAX_VALUE), i);
} else if (arr[mid] > i && arr.length > 1) {
console.log('mid higher', arr[mid], i);
binarySearch(arr.splice(0, mid), i);
} else {
console.log('not here', i);
return -1;
}
}
var result = binarySearch(a, 100);
console.log(result);
原文由 4m1r 发布,翻译遵循 CC BY-SA 4.0 许可协议
您没有明确返回递归内部调用(即
return binarySearch()
),因此调用堆栈展开时没有返回值。像这样更新您的代码:查看 工作小提琴