###### tags: `LeetCode` `Binary Search` `Medium` # LeetCode #33 [Search in Rotated Sorted Array](https://leetcode.com/problems/search-in-rotated-sorted-array/) ### (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,5,6,7] 在下標 3 處經旋轉後可能變為 [4,5,6,7,0,1,2] 。 給你 旋轉後 的數組 nums 和一個整數 target ,如果 nums 中存在這個目標值 target ,則返回它的下標,否則返回 -1 。 --- 因為這題要比較左右的值, 因此不能用左閉右開, 要使用左閉右閉。 首先比較中間的值與左邊的值, 若中值大於左值, 則代表左邊部分是正常的, 此時若目標值在左值範圍中則將右值改為中值, 其餘情況則將左值改為中值+1。 而若中值小於左值, 則代表中值-右值部分為正常遞增, 此時先檢查若目標值介於其中, 則將左值改為中值, 其餘情況則將右值改為中值-1。 --- ``` class Solution { public: int search(vector<int>& nums, int target) { if(!nums.size())return -1; int l=0, r=nums.size()-1; while(l<r){ int m = l+(r-l)/2; if(nums[m]==target)return m; if(nums[l]<=nums[m]){ if(target>=nums[l]&&target<=nums[m])r=m; else l=m+1; } else{ if(target>=nums[m]&&target<=nums[r])l=m; else r=m-1; } } if(target==nums[l])return l; return -1; } }; ```