美文网首页
寻找旋转排序数组中的最小值 II

寻找旋转排序数组中的最小值 II

作者: yellowone | 来源:发表于2020-07-22 08:12 被阅读0次

leecode 154

package main

import "fmt"

/*
假设按照升序排序的数组在预先未知的某个点上进行了旋转。

( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] )。

请找出其中最小的元素。

注意数组中可能存在重复的元素。

示例 1:

输入: [1,3,5]
输出: 1
示例 2:

输入: [2,2,2,0,1]
输出: 0
*/

func main() {
    fmt.Printf("%+v",findMin([]int{3,1,3}))
}

func findMin(nums []int) int {
    i, j := 0, len(nums)-1
    for i < j {
        mid := (i + j) / 2
        //fmt.Printf("%d %d %d\n",i,j,mid)
        if nums[mid] < nums[j]{
            j = mid
            continue
        }
        if nums[mid] > nums[j]{
            i = mid + 1
            continue
        }
        j --
    }
    return nums[i]
}

相关文章

网友评论

      本文标题:寻找旋转排序数组中的最小值 II

      本文链接:https://www.haomeiwen.com/subject/bdoakktx.html