二分查找
题目
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
提示:
- 你可以假设 nums 中的所有元素是不重复的。
- n 将在 [1, 10000]之间。
- nums 的每个元素都将在 [-9999, 9999]之间。
边界条件
while(left <= right) return()退出循环
不知道怎么写边界条件
var search = function(nums, target) {
//二分法,我会
var left = 0,right = nums.length -1
while(left<=right){
var middle = Math.floor((left + right)/2)
if(nums[middle] > target) {
right = middle -1;
}else if(nums[middle] < target) {
left = middle + 1
}else{
return middle
}
}
return -1
};

浙公网安备 33010602011771号