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

旋转数组的最小数字

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的控制

全部评论

相关推荐

ResourceUt...:楼主有自己的垃圾箱,公司也有自己的人才库
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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