###### tags: `LeetCode` `Binary Search` `Medium` # LeetCode #81 [Search in Rotated Sorted Array II](https://leetcode.com/problems/search-in-rotated-sorted-array-ii/) ### (Medium) 已知存在一個按非降序排列的整數數組 nums ,數組中的值不必互不相同。 在傳遞給函數之前,nums 在預先未知的某個下標 k(0 <= k < nums.length)上進行了 旋轉 ,使數組變為 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]](下標 從 0 開始 計數)。例如, [0,1,2,4,4,4,5,6,6,7] 在下標 5 處經旋轉後可能變為 [4,5,6,6,7,0,1,2,4,4] 。 給你 旋轉後 的數組 nums 和一個整數 target ,請你編寫一個函數來判斷給定的目標值是否存在於數組中。如果 nums 中存在這個目標值 target ,則返回 true ,否則返回 false 。 --- 使用 if((nums[l] == nums[m]) && (nums[r] == nums[m])) {++l; --r;} 消除重複元素, 除此之外與 [#33](https://hackmd.io/AqU1txS4Q06_R4uQdNC4QA) 相同 --- ``` class Solution { public: bool search(vector<int>& nums, int target) { int l=0, r=nums.size()-1; while(l<=r){ int m = (l+r)>>1; if(nums[m]==target)return 1; if((nums[l] == nums[m]) && (nums[r] == nums[m])) {++l; --r;} else if(nums[l]<=nums[m]){ if(target>=nums[l]&&target<nums[m])r=m-1; else l=m+1; } else{ if(target>nums[m]&&target<=nums[r])l=m+1; else r=m-1; } } return 0; } }; ```