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

旋转数组的最小数字

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

class Solution {
public:
    int minNumberInRotateArray(vector<int> rotateArray) {
        int arrlen = rotateArray.size();
        if (arrlen < 3) {
            return min(rotateArray[0], rotateArray[1]);
        }
        if (rotateArray[arrlen - 1] > rotateArray[0]) {
            return rotateArray[0];
        }


        int m = int(arrlen / 2) + 1;
        vector<int> lv;
        lv.assign(rotateArray.begin(), rotateArray.end() - m+1);
        int l = minNumberInRotateArray(lv);
        vector<int> rv;
        rv.assign(rotateArray.begin() + m-1, rotateArray.end());
        int r = minNumberInRotateArray(rv);
        return min(l, r);
    }
};

简单的二分法处理,关键在于中间值m的控制

全部评论

相关推荐

07-15 16:52
已编辑
门头沟学院 Java
周五投的,流程今天结束
投递地平线等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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