mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-25 03:11:41 +08:00
规范格式
This commit is contained in:
@ -0,0 +1,65 @@
|
||||
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
|
||||
}
|
Reference in New Issue
Block a user