二分查找:给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
示例1:
输入:nums = [-1,0,3,5,9,12],target = 9
输出:4
示例2:
输入:nums = [-1,0,3,5,9,12],target = 2
输出:-1
class Solution {
public int search(int[] nums, int target) {
//定义target在[left,right]区间中
int left = 0;
int right = nums.length-1;
//循环,不断的缩小目标值所在的区间
while(left <= right) {
int mid = (left + right)/2;
if(target>nums[mid]) {//目标值在右区间
left = mid + 1;
} else if(target <nums[mid]) {//目标值在左区间
right = mid - 1;
} else {
return mid;
}
}
return -1;
}
}