【剑指Offer】旋转数组的最小数字

题目描述

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。

算法分析

我觉得这道题目挺没有意思,最直接的一个做法是遍历整个数组,它举了一个递减排序的数组,这里只需要找到旋转点是可以用二分的,不确定旋转数组是否是有序的话,就只能用第一个方法了。

代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray) {
if(rotateArray.size() == 0){
return 0;
} else{
int first = rotateArray[0];
int i = 1;
while(rotateArray[i] != '\0'){
if(rotateArray[i] < first){
break;
//return rotateArray[i];
}
i++;
}
return rotateArray[i];
}
}
};

class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray) {
int n = rotateArray.size();
if (n == 0) return 0;
else {
int min = rotateArray[0];
for (auto i : rotateArray) {
if (i < min) min = i;
}

return min;
}
}
};