问题描述:给定一个 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;
}
参考:
标签:二分,target,nums,int,mid,查找 From: https://www.cnblogs.com/i9code/p/18000328