Search in Rotated Sorted Array
Description
Code
class Solution {
public int search(int[] nums, int target) {
if (nums.length == 0) return -1;
int minIdx = findMinIdx(nums);
if (target == nums[minIdx]) return minIdx;
int m = nums.length;
int start = (target <= nums[m - 1]) ? minIdx : 0;
int end = (target > nums[m - 1]) ? minIdx : m - 1;
while (start <= end) {
int mid = start + (end - start) / 2;
if (nums[mid] == target) return mid;
else if (target > nums[mid]) start = mid + 1;
else end = mid - 1;
}
return -1;
}
public int findMinIdx(int[] nums) {
int start = 0, end = nums.length - 1;
while (start < end) {
int mid = start + (end - start) / 2;
if (nums[mid] > nums[end]) start = mid + 1;
else end = mid;
}
return start;
}
}Last updated