获得二进制搜索的迭代次数

问题描述 投票:0回答:1

我正在尝试实现一个二进制搜索功能,该功能返回元素的索引以及获取元素所需的迭代次数。

function binarySearch(array, number) {
    var obj = {}, index, count = 0;
    var start = 0;
    var end = array.length - 1;
    var middle = Math.floor((start + end) / 2);

    while(array[middle] !== number && start <= end) {
        if(number < array[middle]) end = middle - 1;
        else start = middle + 1;
        middle = Math.floor((start + end) / 2);
    }

    array[middle] === number ? obj.index = middle : obj.index = -1;
    obj.count++
    return obj;
}

我预期的输出为[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22], 3。是obj = {index:2, count:3},但正在获取obj ={index;2, count:NaN}

javascript binary-search
1个回答
0
投票

您将获得count: NaN,因为您从未初始化obj.count。未定义的值加1会产生NaN

您需要在循环中增加count。然后最后您可以分配obj.count = count;

并且如果要使用三元表达式,请在赋值的源中进行操作,而不要在每个条件下都重复该赋值。

function binarySearch(array, number) {
  var obj = {},
    index, count = 0;
  var start = 0;
  var end = array.length - 1;
  var middle = Math.floor((start + end) / 2);

  while (array[middle] !== number && start <= end) {
    if (number < array[middle]) end = middle - 1;
    else start = middle + 1;
    middle = Math.floor((start + end) / 2);
    count++;
  }

  obj.index = array[middle] === number ? middle : -1;
  obj.count = count;
  return obj;
}

console.log(binarySearch([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22], 3));
© www.soinside.com 2019 - 2024. All rights reserved.