美文网首页
寻找旋转排序数组中的最小值 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