二分查找javascript

607 阅读1分钟

查找算法

1.二分查找

思想:

假设表中元素是按升序排列,将表中间位置记录的[关键字]与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置[记录]将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的[记录],使查找成功,或直到子表不存在为止,此时查找不成功。

function binarySearch(arr,target){
//arr是排好序的,从小到大
    let begin = 0
    let end = arr.length-1
    while(begin <= end){
        let mid = (end + begin)>>>1//位运算,无符号右移一位,Math.floor((begin+end)/2)
        if(arr[mid] == target){
            return mid
        }else if(arr[mid] > target){
            end = mid-1
        }else if(arr[mid] < target){
            begin = mid + 1
        }
    }
    return -1
}

while中当begin==end时,需要进行最后一次判断,当arr = [1],target=1时,begin=0,end=0,如果判断条件是while(begin < end),则直接返回-1