1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
public int search (int[] nums, int target) {
// 左指针:起始下标
int left = 0;
// 右指针:结束下标,闭区间 [left, right]
int right = nums.length - 1;
while (left <= right) {
int mid = left + ((right - left) >> 1);
if (nums[mid] < target) {
// 目标值在右半区,左指针右移
left = mid + 1;
} else if (nums[mid] == target) {
// 找到目标值,返回对应下标
return mid;
} else {
// 目标值在左半区,右指针左移
right = mid - 1;
}
}
// 遍历完无目标值,返回-1
return -1;
}
|