leetcode链接:搜索旋转排序数组
ps:
本题是二分查找的变形,旋转排序数组之后其实会形成两个有序的区间。算出平均下标先判断是否与 target
相等,因为这样可以减少代码的冗余。如果前者不成立则使用平均下标元素 midIndex
与 数组最后一个元素判断大小(因为我们可以确定第二个有序区间的最大值,而确定不了第一个有序区间的最大值),若小于则当前 midIndex
就在第二个有序区间中,反之在第一个有序区间。知道在哪个区间后,在判断 target
是否在这个区间中以及 nums[midIndex]
与 target
的大小。
代码:
int search(int* nums, int numsSize, int target){
int left = 0;
int right = numsSize - 1;
while (left <= right) {
int midIndex = left + ((right - left) / 2);
if (nums[midIndex] == target) {
return midIndex;
} else if (nums[midIndex] < nums[right]) {
// 在第二个有序区间
if (target <= nums[right] && nums[midIndex] < target) {
left = midIndex + 1;
} else {
right = midIndex - 1;
}
} else {
// 第一个有序区间
if (target >= nums[left] && nums[midIndex] > target) {
right = midIndex - 1;
} else {
left = midIndex + 1;
}
}
}
return -1;
}