Files
LeetCode-Go/leetcode/0153.Find-Minimum-in-Rotated-Sorted-Array/153. Find Minimum in Rotated Sorted Array.go
2020-08-07 17:06:53 +08:00

66 lines
1.3 KiB
Go

package leetcode
// 解法一 二分
func findMin(nums []int) int {
low, high := 0, len(nums)-1
for low < high {
if nums[low] < nums[high] {
return nums[low]
}
mid := low + (high-low)>>1
if nums[mid] >= nums[low] {
low = mid + 1
} else {
high = mid
}
}
return nums[low]
}
// 解法二 二分
func findMin1(nums []int) int {
if len(nums) == 0 {
return 0
}
if len(nums) == 1 {
return nums[0]
}
if nums[len(nums)-1] > nums[0] {
return nums[0]
}
low, high := 0, len(nums)-1
for low <= high {
mid := low + (high-low)>>1
if nums[low] < nums[high] {
return nums[low]
}
if (mid == len(nums)-1 && nums[mid-1] > nums[mid]) || (mid < len(nums)-1 && mid > 0 && nums[mid-1] > nums[mid] && nums[mid] < nums[mid+1]) {
return nums[mid]
}
if nums[mid] > nums[low] && nums[low] > nums[high] { // mid 在数值大的一部分区间里
low = mid + 1
} else if nums[mid] < nums[low] && nums[low] > nums[high] { // mid 在数值小的一部分区间里
high = mid - 1
} else {
if nums[low] == nums[mid] {
low++
}
if nums[high] == nums[mid] {
high--
}
}
}
return -1
}
// 解法三 暴力
func findMin2(nums []int) int {
min := nums[0]
for _, num := range nums[1:] {
if min > num {
min = num
}
}
return min
}