码迷,mamicode.com
首页 > 编程语言 > 详细

旋转数组的最小数字

时间:2015-10-26 18:26:42      阅读:228      评论:0      收藏:0      [点我收藏+]

标签:

题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减序列的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。
分析:此题使用暴力的方法的时间复杂度是O(N),如果是采用二分查找法的时间复杂度是O(lgN)。二分查找法是先定义两个指针分别指向数组的头和尾,将中间元素和第一个元素比较,如果中间元素大于第一个元素,则最小的元素在后面一段中。注意该题的特殊情况处理1,0,1,1,1,1 / 1,1,1,1,0,1和1,1,1,1,0  对于中间元素和第一个元素还有最后一个元素相等的情况下,只能是right-- .
class Solution {
public:
    int minNumberInRotateArray(vector<int> rotateArray) {
//      不可以去掉!!! 必须要有合法性检查
        if(rotateArray.size()==0){
            return 0;
        }
/*        int min = rotateArray[0];
        for(int i = 0; i < rotateArray.size(); i++) {
            if(min > rotateArray[i]) 
                min = rotateArray[i];
        }
        return min;
*/
        
        int left = 0, right = rotateArray.size() - 1;
        if(rotateArray[left] < rotateArray[right])
            return rotateArray[left];
        while(left < right) {
//            if(rotateArray[left] < rotateArray[rotateArray.size() / 2]) 
            int mid = (left + right) >> 1;
            if(rotateArray[mid] > rotateArray[left])
//                left = rotateArray.size() / 2;
                left = mid;
            else if(rotateArray[mid] < rotateArray[left])
//                right = rotateArray.size() / 2;
                right = mid;
            else {
                if(rotateArray[left] == rotateArray[right]) 
                    right--;
                else 
                    left = mid;
            }
            if(right - left == 1) 
                return rotateArray[right];
        }
        return rotateArray[right];
        
    }
};

 

旋转数组的最小数字

标签:

原文地址:http://www.cnblogs.com/fengcq1129/p/4911680.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!