二分查找3搜索旋转排序数组Ⅱ(medium)
Posted 念奕玥
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分查找3搜索旋转排序数组Ⅱ(medium)相关的知识,希望对你有一定的参考价值。
leetcode 搜索旋转排序数组Ⅱ
分析:一个初始有序的数组,经过以某一点为中心的旋转后,判断数组中是否存在目标值。关键词:有序,是否存在目标值。
方法:二分查找,依据题意进行相应的变形。
思路:总体依据二分查找的思想。经过旋转后,无法判断mid左右两侧哪一边是有序的(总有一边是有序的),因此可以借助nums[mid]与nums[left]、nums[right]进行比较来判断。然后根据有序的一侧去查询target,在依此来变化left和right位置。
class Solution {
public boolean search(int[] nums, int target) {
if(nums.length==0||nums==null) return false;
int left=0,right=nums.length-1;
while(left<=right){
int mid= left+(right-left)/2;
if(nums[mid]==target)
return true;
//排除[10111]解答错误
if(nums[left]==nums[mid]){
left++;
continue;
//因为是nums[left]与nums[mid]重复了,
//所以不要当前nums[left]也可以,重新找mid
}
//左边有序
if(nums[left]<nums[mid]){
if(target<nums[mid]&&target>=nums[left]){
right=mid-1;
}else{
left=mid+1;
}
//右边有序
}else{
if(target>nums[mid]&& target<=nums[right]){
left=mid+1;
}else{
right=mid-1;
}
}
}
return false;
}
}
以上是关于二分查找3搜索旋转排序数组Ⅱ(medium)的主要内容,如果未能解决你的问题,请参考以下文章
二分查找(通过相对位置判断区间位置)--17--二分--LeetCode33搜索旋转排序数组