★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-uquwplny-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Given a sorted array consisting of only integers where every element appears twice except for one element which appears once. Find this single element that appears only once.git
Example 1:github
Input: [1,1,2,3,3,4,4,8,8] Output: 2
Example 2:數組
Input: [3,3,7,7,10,11,11] Output: 10
Note: Your solution should run in O(log n) time and O(1) space.微信
給定一個只包含整數的有序數組,每一個元素都會出現兩次,惟有一個數只會出現一次,找出這個數。app
示例 1:this
輸入: [1,1,2,3,3,4,4,8,8] 輸出: 2
示例 2:spa
輸入: [3,3,7,7,10,11,11] 輸出: 10
注意: 您的方案應該在 O(log n)時間複雜度和 O(1)空間複雜度中運行。code
1 class Solution { 2 func singleNonDuplicate(_ nums: [Int]) -> Int { 3 var left:Int = 0 4 var right:Int = nums.count - 1 5 while (left < right) 6 { 7 var mid:Int = left + (right - left) / 2 8 if mid % 2 == 1 9 { 10 mid -= 1 11 } 12 if nums[mid] == nums[mid + 1] 13 { 14 left = mid + 2 15 } 16 else 17 { 18 right = mid 19 } 20 } 21 return nums[left] 22 } 23 }
40mshtm
1 class Solution { 2 func singleNonDuplicate(_ nums: [Int]) -> Int { 3 var low = 0 4 var high = nums.count - 1 5 var medium = (low + high)/2 6 7 while (low < high) { 8 if medium % 2 == 0 { 9 if nums[medium] == nums[medium + 1] { 10 low = medium + 2 11 } else { 12 high = medium 13 } 14 } else { 15 if nums[medium] == nums[medium - 1] { 16 low = medium + 1 17 } else { 18 high = medium 19 } 20 } 21 medium = (low + high)/2 22 } 23 24 return nums[low] 25 } 26 }
1 class Solution { 2 func singleNonDuplicate(_ nums: [Int]) -> Int { 3 var left = 0 4 var right = nums.count 5 6 var middle = nums.count / 2 7 while middle != 0 { 8 guard middle - 1 >= 0 && middle + 1 <= nums.count-1 else 9 { 10 return nums[middle] 11 } 12 if nums[middle] == nums[middle-1]{ 13 if middle % 2 == 0{ 14 right = middle - 1 15 }else{ 16 left = middle + 1 17 } 18 19 }else if nums[middle] == nums[middle+1] { 20 if middle % 2 == 0{ 21 left = middle + 1 22 }else 23 { 24 right = middle-1 25 } 26 27 }else{ 28 return nums[middle] 29 } 30 middle = (left + right)/2 31 } 32 return nums[0] 33 } 34 }
48ms
1 class Solution { 2 func singleNonDuplicate(_ nums: [Int]) -> Int { 3 var dictionary = [Int: Int]() 4 5 for number in nums { 6 var value = dictionary[number] ?? 0 7 value += 1 8 dictionary[number] = value 9 } 10 11 var result = 0 12 13 for key in dictionary.keys where dictionary[key] == 1 { 14 result = key 15 break 16 } 17 18 return result 19 } 20 }
68ms
1 class Solution { 2 func singleNonDuplicate(_ numbers: [Int]) -> Int { 3 func search(_ left: Int, _ right: Int) -> Int { 4 let middle = (left + right) / 2 5 6 if middle > 0 && numbers[middle - 1] == numbers[middle] { 7 if (middle - 1) % 2 == 0 { 8 return search(middle + 1, right) 9 } else { 10 return search(left, middle - 2) 11 } 12 } 13 14 if middle < (numbers.count - 1) && numbers[middle] == numbers[middle + 1] { 15 if middle % 2 == 0 { 16 return search(middle + 2, right) 17 } else { 18 return search(left, middle - 1) 19 } 20 } 21 22 return numbers[middle] 23 } 24 return search(0, numbers.count - 1) 25 } 26 }