Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.

(i.e., [0,0,1,2,2,5,6] might become [2,5,6,0,0,1,2]).

You are given a target value to search. If found in the array return true, otherwise return false.

Example 1:

Input: nums = [2,5,6,0,0,1,2], target = 0
Output: true

Example 2:

Input: nums = [2,5,6,0,0,1,2], target = 3
Output: false

Follow up:

  • This is a follow up problem to Search in Rotated Sorted Array, where nums may contain duplicates.
  • Would this affect the run-time complexity? How and why?

这道是之前那道 Search in Rotated Sorted Array 的延伸,现在数组中允许出现重复数字,这个也会影响我们选择哪半边继续搜索,由于之前那道题不存在相同值,我们在比较中间值和最右值时就完全符合之前所说的规律:如果中间的数小于最右边的数,则右半段是有序的,若中间数大于最右边数,则左半段是有序的。而如果可以有重复值,就会出现来面两种情况,[3 1 1] 和 [1 1 3 1],对于这两种情况中间值等于最右值时,目标值3既可以在左边又可以在右边,那怎么办么,对于这种情况其实处理非常简单,只要把最右值向左一位即可继续循环,如果还相同则继续移,直到移到不同值为止,然后其他部分还采用 Search in Rotated Sorted Array 中的方法,可以得到代码如下:

class Solution {
public:
bool search(vector<int>& nums, int target) {
int n = nums.size(), left = , right = n - ;
while (left <= right) {
int mid = (left + right) / ;
if (nums[mid] == target) return true;
if (nums[mid] < nums[right]) {
if (nums[mid] < target && nums[right] >= target) left = mid + ;
else right = mid - ;
} else if (nums[mid] > nums[right]){
if (nums[left] <= target && nums[mid] > target) right = mid - ;
else left = mid + ;
} else --right;
}
return false;
}
};

Github 同步地址:

https://github.com/grandyang/leetcode/issues/81

类似题目:

Search in Rotated Sorted Array

参考资料:

https://leetcode.com/problems/search-in-rotated-sorted-array-ii/

https://leetcode.com/problems/search-in-rotated-sorted-array-ii/discuss/28194/C%2B%2B-concise-log(n)-solution

https://leetcode.com/problems/search-in-rotated-sorted-array-ii/discuss/28218/My-8ms-C%2B%2B-solution-(o(logn)-on-average-o(n)-worst-case)

LeetCode All in One 题目讲解汇总(持续更新中...)

最新文章

  1. 自己来实现一个简易的OCR
  2. 0-Spark高级数据分析-读书笔记
  3. dlmalloc(Android bionic C库的malloc实现)简介
  4. HDU 3681 Prison Break(BFS+二分+状态压缩DP)
  5. [BZOJ 1086] [SCOI2005] 王室联邦 【树分块】
  6. 匿名函数中undefined形参疑问(转载)
  7. 乐在其中设计模式(C#) - 建造者模式(Builder Pattern)
  8. Http 1.x弊端与Http 2.0比较
  9. JUnit4测试报错:class not found XXX
  10. 0 ardunio processing 显示三轴数据
  11. 2.28 查看webdriver API
  12. Linux NTP
  13. Linux下通过关键字模糊查找搜索文件
  14. 1.cassandra的搭建
  15. Javascript框架
  16. SpringBoot+RestTemplate 简单包装
  17. 用L脚本语言实现&amp;quot;L脚本语言控制台&amp;quot;
  18. GIS-012-ArcGIS JS API 绘图
  19. 洛谷P4799 世界冰球锦标赛 CEOI2015 Day2 meet-in-the-middle
  20. sendEmail实现邮件报警

热门文章

  1. javascript json写法
  2. 【题解】Informacije [COCI2012]
  3. LocalDB 从2017更换到2014后一直显示连接不正确解决方案
  4. Installing on Kubernetes with NATS Operator
  5. C# - VS2019调用AForge库实现调用摄像头拍照功能
  6. Linux文本文件——文本编辑器Vim
  7. 二十三:原型模式详解(clone复制方法源码)
  8. Scrum冲刺第三篇
  9. 动态改变伪元素样式的方(用:after和:before生成的元素)
  10. Vue、Element-ui项目中如何使用Iconfont(阿里图标库)