整數數組 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 。
你必須設計一個時間復雜度為 O(log n) 的算法解決此問題。
示例 1:
輸入:nums = [4,5,6,7,0,1,2], target = 0
輸出:4
示例 2:
輸入:nums = [4,5,6,7,0,1,2], target = 3
輸出:-1
示例 3:
輸入:nums = [1], target = 0
輸出:-1
提示:
1 <= nums.length <= 5000
-104 <= nums[i] <= 104
nums 中的每個值都 獨一無二
題目數據保證 nums 在預先未知的某個下標上進行了旋轉
-104 <= target <= 104
var search = function(nums, target) {var left = 0,right = nums.length-1// 特殊情況判斷if(nums.length==0){return -1}if(nums.length==1){return nums[0]==target?0:-1}// while(left<=right)檢查到了當target在左指針和右指針重合的位置,如果是while(left<right)那么檢查不到重合的位置while(left<=right){var mid = Math.floor((left+right)/2)if(nums[mid] == target){return mid}else{// 中間的數字小于最右邊的數字,說明右邊一定是有序的if(nums[mid]<nums[right]){if(nums[mid]<target&&target<=nums[right]){left=mid+1}else{right = mid-1}}else{// 右邊是無序的,左邊是有序的if(nums[mid]>target&&target>=nums[left]){right = mid-1}else{left = mid+1}}}}return -1
};