二分查找

题目

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
提示:

  1. 你可以假设 nums 中的所有元素是不重复的。
  2. n 将在 [1, 10000]之间。
  3. 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
};
posted @ 2023-08-03 14:00  Liinboc  阅读(7)  评论(0)    收藏  举报