二分查找

704. 二分查找(Easy)

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

示例 1:
输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4
示例 2:
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1
//思路:典型的二分查找
//写法一:在区间 [l,r]中查找target元素
public int search(int[] nums, int target) {
  int l = 0;
  int r = nums.length -1;
  while(l<=r){
    int mid = (r-l)/2 + l;
    if(nums[mid]==target){
      return mid;
    }else if(nums[mid]>target){
      r = mid-1;
    }else{
      l = mid+1;
    }
  }
  return -1;
}
//写法二:在区间 [l,r)中查找target元素
public int search(int[] nums, int target) {
  int l = 0;
  int r = nums.length;
  while(l<r){
    int mid = (r-l)/2 + l;
    if(nums[mid]==target){
      return mid;
    }else if(nums[mid]>target){
      r = mid;
    }else{
      l = mid+1;
    }
  }
  return -1;
}

参考:

posted @ 2024-01-31 23:05  行行行行星  阅读(8)  评论(0)    收藏  举报