[Swift]LeetCode81. 搜索旋轉排序數組 II | Search in Rotated Sorted Array II

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(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:函數

  • 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?

假設按照升序排序的數組在預先未知的某個點上進行了旋轉。this

( 例如,數組 [0,0,1,2,2,5,6] 可能變爲 [2,5,6,0,0,1,2] )。spa

編寫一個函數來判斷給定的目標值是否存在於數組中。若存在返回 true,不然返回 falsecode

示例 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 }
相關文章
相關標籤/搜索