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

旋转数组的最小数字

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

class Solution {
public:
    int minNumberInRotateArray(vector<int> rotateArray) {
        if(rotateArray[0]<rotateArray[1]&&rotateArray[0]<rotateArray[rotateArray.size()-1])
            return rotateArray[0];
        int L=0,R=rotateArray.size()-1;
        while(L<R){
            int mid=(L+R)/2;
            if(mid>0&&rotateArray[mid]<rotateArray[mid-1])
                return rotateArray[mid];
            else if(rotateArray[mid]>rotateArray[0]){
                L=mid+1;
            }
            
            else if(rotateArray[mid]==rotateArray[0]){
                int ans=1;
                while(rotateArray[ans++]>=rotateArray[0]);
                if(ans<=mid)
                    R=mid-1;
                else L=mid+1;
            }
            else R=mid-1;
        }
        return rotateArray[L];
    }
};
全部评论

相关推荐

那一天的Java_Java起来:他本来公司就是做这个的,不就是正常的游戏客户端和服务器开发,软硬件联动,有啥恶心不恶心的,提前告诉你就是怕你接受不了,接受不了就没必要再往后走流程浪费时间,虽然这公司是一坨。
点赞 评论 收藏
分享
05-12 17:28
已编辑
门头沟学院 硬件开发
ldf李鑫:不说公司名祝你以后天天遇到这样的公司
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务