class Solution {
// o(log n) 二分法
// 二分法的难点在于等号
// 判断nums[mid] 与 nums[left] 的关系,如果nums[mid] >= nums[left] ,说明 left 到 mid 有序
// if (nums[mid] < nums[left]) 说明 mid 到right 有序,
// 判断target是否落在有序部分,若不在则切换子数组
// 据此缩小范围
public int search(int[] nums, int target) {
int left = 0, right = nums.length - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (nums[mid] == target) {
return mid;
} else if (nums[mid] >= nums[left]) {
if (target >= nums[left] && target < nums[mid]) {
right = mid - 1;
} else {
left = mid + 1;
}
} else {
if (target > nums[mid] && target <= nums[right]) {
left = mid + 1;
} else {
right = mid - 1;
}
}
}
return -1;
}
}