LeetCode 33 搜索旋转排序数组(Java)
Posted 上帝爱吃苹果
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 33 搜索旋转排序数组(Java)相关的知识,希望对你有一定的参考价值。
思路:按照上图两种情形分别进行二分查找
public int search(int[] nums, int target) {
if(nums==null||nums.length<1) return -1;
int left = 0;
int right = nums.length - 1;
while (left <= right) {
int mid = left + (right - left) / 2;
if (nums[mid] == target) return mid;
//条件1
if (nums[mid] >= nums[left]) {
if (target < nums[mid] && target >= nums[left]) {
right = mid - 1;
}else {
left = mid + 1;
}
}
//条件2
if (nums[mid] <= nums[right]) {
if (target > nums[mid] && target <= nums[right]) {
left = mid + 1;
}else {
right = mid - 1;
}
}
}
return -1;
}
LeetCode81 搜索旋转排序数组题目的延伸,本题中的 nums 可能包含重复元素。
- 这种情况下只需要举出能够最坏情况的数据是 [1,1,1,1... 1] 里有一个0即可。
- 在这种情况下是无法使用二分法的,复杂度是O(n)
- 因此写个for循环最坏也是O(n),那就写个for循环就好了。
public boolean search(int[] A, int target) {
for (int i = 0; i < A.length; i ++) {
if (A[i] == target) {
return true;
}
}
return false;
}
以上是关于LeetCode 33 搜索旋转排序数组(Java)的主要内容,如果未能解决你的问题,请参考以下文章