javascript - 如果我使用两个 "if"语句而不是仅使用一个 "if/else"语句,为什么二进制搜索算法不起作用?

标签 javascript algorithm if-statement binary-search

<分区>

这个代码块工作得很好。这是一个用 javascript 编写的二进制搜索算法。我从一个网站上收集的。

function binarySearch(arr, target) {
    let left = 0;
    let right = arr.length - 1;
    while (left <= right) {
        const mid = left + Math.floor((right - left) / 2);
        if (arr[mid] === target) {
            return mid;
        }
        if (arr[mid] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return -1;
}

var result = binarySearch([2,3,4,5,6,7,8,9,10],2);
console.log(result);

但如果我以这种方式更改 while 循环内的代码,它就不起作用了。 我已经尝试了几次但无济于事。请帮我。有什么问题?

function binarySearch(arr, target) {
    let left = 0;
    let right = arr.length - 1;
    while (left <= right) {
        const mid = left + Math.floor((right - left) / 2);
        if (arr[mid] === target) {
            return mid;
        }

        if (arr[mid] < target) {
            left = mid + 1;
        }
        // Look here. Here is my problem
        if(arr[mid] > target){
            right = mid - 1;
        }
    }
    return -1;
}

var result = binarySearch([2,3,4,5,6,7,8,9,10],2);
console.log(result);

最佳答案

if (arr[mid] === target) {
    return mid;
}

if (arr[mid] < target) {
    left = mid + 1;
}

if(arr[mid] > target){
    right = mid - 1;
}

if (arr[mid] === target) {
    return mid;
}

if (arr[mid] < target) {
    left = mid + 1;
} else {
    right = mid - 1;
}

在这种情况下是等价的。

关于javascript - 如果我使用两个 "if"语句而不是仅使用一个 "if/else"语句,为什么二进制搜索算法不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55028183/

相关文章:

javascript - JqueryTools 在按钮单击时公开关闭

Javascript:在滚动上做动画

javascript - CKEDITOR - 关闭 html 编码

algorithm - 查找 2D M x N 网格中封闭空间的存在

algorithm - 如何通过快速比较哈希来查找插入/删除?

c - 不同二项式系数算法的效率比较

java - 为什么最后的 else 语句没有在这里打印/执行?

json - jq 忽略 else 子句

javascript - 刷新页面时 HTML 5 Web SQL 数据库事务提交或回滚

mysql - 在选择中,当列具有特定值时添加假行