使用 JavaScript 使用二进制搜索在数组中搜索
问题
我们需要编写一个JavaScript函数,它接受一个排序的数字数组(递增顺序),arr作为第一个参数,一个目标数字作为第二个参数。由于数组已排序,我们的函数应该使用二进制搜索算法在数组arr中搜索目标。
如果目标存在,那么我们应该返回它的索引,否则我们应该返回-1。
例如,如果函数的输入是
输入
const arr = [3, 5, 7, 9, 11, 13, 15, 16, 18, 21, 24, 25, 28]; const target = 13;
输出
const output = 5;
示例
以下是代码-
const arr = [3, 5, 7, 9, 11, 13, 15, 16, 18, 21, 24, 25, 28];
const target = 13;
const binarySearch = (arr = [], target) => {
const helper = (low, high) => {
if (low > high) {
return -1
}
const middle = Math.floor((low + high) / 2)
if (arr[middle] === target) {
return middle
} if (arr[middle] < target) {
return helper(middle + 1, high)
}
return helper(low, middle - 1)
}
return helper(0,arr.length- 1)
};
console.log(binarySearch(arr, target));输出结果5
热门推荐
10 小学毕业父母简短祝福语
11 幼儿生日祝福语模板简短
12 新娘妈妈的祝福语简短
13 邻居聚会祝福语大全简短
14 十条祝福语简短
15 给同学祝福语的简短
16 过年祝福语简短祝妈妈
17 祝女儿简短祝福语大全
18 恩师诗词祝福语简短大全