⭐️ 题目描述
🌟 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;
}