查找算法
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