★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-tvfmvreu-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.git
(i.e., [0,0,1,2,2,5,6]
might become [2,5,6,0,0,1,2]
).github
You are given a target value to search. If found in the array return true
, otherwise return false
.數組
Example 1:微信
Input: nums = [2, target = 0 Output: true ,5,6,0,0,1,2]
Example 2:app
Input: nums = [2, target = 3 Output: false,5,6,0,0,1,2]
Follow up:函數
nums
may contain duplicates.假設按照升序排序的數組在預先未知的某個點上進行了旋轉。this
( 例如,數組 [0,0,1,2,2,5,6]
可能變爲 [2,5,6,0,0,1,2]
)。spa
編寫一個函數來判斷給定的目標值是否存在於數組中。若存在返回 true
,不然返回 false
。code
示例 1:
輸入: nums = [2, target = 0 輸出: true ,5,6,0,0,1,2]
示例 2:
輸入: nums = [2, target = 3 輸出: false,5,6,0,0,1,2]
進階:
nums
可能包含重複元素。12ms
1 class Solution { 2 func search(_ nums: [Int], _ target: Int) -> Bool { 3 if nums.count == 0 { 4 return false 5 } 6 7 var left = 0 8 var right = nums.count - 1 9 10 while left < right { 11 let middle = left + (right - left) / 2 12 if nums[middle] == target { 13 return true 14 } 15 if nums[middle] > nums[right] { 16 if nums[middle] > target && nums[left] <= target { 17 right = middle 18 } else { 19 left = middle + 1 20 } 21 } else if nums[middle] < nums[right] { 22 if nums[middle] < target && nums[right] >= target { 23 left = middle + 1 24 } else { 25 right = middle 26 } 27 } else { 28 right -= 1 29 } 30 } 31 32 return nums[left] == target 33 } 34 }
16ms
1 class Solution { 2 func search(_ nums: [Int], _ target: Int) -> Bool { 3 4 if nums.count <= 0 { return false } 5 6 var lo = 0 7 var hi = nums.count - 1 8 var mid = (lo + hi) / 2 9 10 while lo <= hi { 11 mid = (lo + hi) / 2 12 13 //print("Check Piv [\(lo) \(mid) \(hi)] => {\(nums[lo]) \(nums[mid]) \(nums[hi])}") 14 15 if nums[mid] == target { 16 return true 17 } 18 19 if nums[mid] > nums[lo] { 20 21 if target >= nums[lo] && target < nums[mid] { 22 hi = mid - 1 23 } else { 24 lo = mid + 1 25 } 26 } else if nums[mid] < nums[lo] { 27 if target > nums[mid] && target <= nums[hi] { 28 lo = mid + 1 29 } else { 30 hi = mid - 1 31 } 32 } else { 33 lo += 1 34 } 35 } 36 return false 37 } 38 }
20ms
1 class Solution { 2 func search(_ nums: [Int], _ target: Int) -> Bool { 3 4 var left = 0, right = nums.count - 1 5 6 while left <= right { 7 let mid = left + (right - left) / 2 8 if nums[mid] == target { 9 return true 10 } 11 if nums[mid] == nums[left] { 12 left += 1 13 } else if nums[mid] > nums[left] { 14 if target >= nums[left] && target < nums[mid] { 15 right = mid - 1 16 } else { 17 left = mid + 1 18 } 19 } else { 20 if target > nums[mid] && target <= nums[right] { 21 left = mid + 1 22 } else { 23 right = mid - 1 24 } 25 } 26 } 27 28 return false 29 } 30 }
40ms
1 class Solution { 2 func search(_ nums: [Int], _ target: Int) -> Bool { 3 var set: Set = Set<Int>.init() 4 for d in nums { 5 if d == target { 6 return true 7 }else { 8 if set.contains(target) { 9 return true 10 }else { 11 set.insert(d) 12 } 13 } 14 } 15 return false 16 } 17 }
44ms
1 class Solution { 2 3 func search(_ nums: [Int], _ target: Int) -> Bool { 4 return nums.contains(target) 5 } 6 }
52ms
1 class Solution { 2 func search(_ nums: [Int], _ target: Int) -> Bool { 3 if nums.isEmpty 4 { 5 return false 6 } 7 8 var distinct = removeDuplicates(nums) 9 10 return searchRec(&distinct, target, start:0, end:distinct.count - 1) 11 } 12 13 func searchRec(_ num: inout [Int], _ target: Int, start: Int, end: Int) -> Bool 14 { 15 if start == end 16 { 17 return num[start] == target 18 } 19 20 let diff = end - start 21 let center = start + (diff - (diff % 2)) / 2 22 23 if num[center] == target 24 { 25 return true 26 } 27 28 if num[start] <= num[center] 29 { 30 if target >= num[start] && target < num[center] 31 { 32 return searchRec(&num, target, start:start, end:center - 1) 33 } 34 35 return searchRec(&num, target, start:center + 1, end:end) 36 } 37 else if num[start] >= num[center] 38 { 39 if target >= num[start] || target < num[center] 40 { 41 return searchRec(&num, target, start:start, end:center - 1) 42 } 43 44 return searchRec(&num, target, start:center + 1, end:end) 45 } 46 47 return false 48 49 } 50 51 func removeDuplicates(_ nums: [Int]) -> [Int] 52 { 53 if nums.isEmpty 54 { 55 return nums 56 } 57 58 var distinct = [nums[0]] 59 var prev = nums[0] 60 61 for val in nums[1..<nums.count] 62 { 63 if val != prev && val != nums[0] 64 { 65 distinct.append(val) 66 } 67 68 prev = val 69 } 70 71 return distinct 72 } 73 }