题解 | #旋转数组的最小数字#

旋转数组的最小数字

http://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba

    # 两个注意点 当left right为相邻值时,最小的是right值
    # 当right值和mid值相等时,无法判断最小值在哪个区间,该情况暴力求解 (10111,11101,20111)
    # 其余情况 二分法:当right>mid时,最小值在左区间;当right<mid时,最小值在右区间
    
    left = 0
    right = len(rotateArray) - 1
    while left <= right:
        if left == right-1:   #left right相邻 right最小值
            return rotateArray[right]
        mid = (left + right) // 2
        if rotateArray[mid] < rotateArray[mid-1]:   # mid<mid-1 直接返回
            return rotateArray[mid]
        if rotateArray[right] > rotateArray[mid]:   #right>mid 左区间
            right = mid
        elif rotateArray[right] < rotateArray[mid]:  #right<mid 右区间
            left = mid
        else:               #right==mid 无法判定 暴力求解
            tmp = rotateArray[0]
            for i in range(len(rotateArray)):
                if tmp > rotateArray[i]:
                    tmp = rotateArray[i]
            return tmp
全部评论

相关推荐

面向对象的火龙果很爱...:去吃一顿炸鸡就走
点赞 评论 收藏
分享
05-21 15:47
门头沟学院 Java
浪漫主义的虹夏:项目有亮点吗,第一个不是纯玩具项目吗,项目亮点里类似ThreadLocal,Redis储存说难听点是花几十分钟绝大部分人都能学会,第二个轮子项目也没体现出设计和技术,想实习先沉淀,好高骛远的自嗨只会害了自己
点赞 评论 收藏
分享
叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务