1.旋转数组的最小数字-无重复值代码实现-leetcode-153
class Solution {
public:
int findMin(vector<int>& nums) {
int l = 0, h = nums.size() - 1;
while(l < h){
int mid = l + (h - l)/2;
if(nums[mid] <= nums[h]){
//mid到h都是有序的
//mid有可能是结果
h = mid;
}
else{
l = mid +1;
}
}
return nums[l];
}
};
2.对于有重复的数字-有一种特殊情况,如果nums[left] = nums[mid]= nums[right],无法知道最小值在哪个区间,需要切到顺序查找。
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型vector
* @return int整型
*/
int minNumberInRotateArray(vector<int>& nums) {
// write code here
int left = 0, right = nums.size() - 1;
while(left < right){
int mid = left + (right - left) / 2;
if(nums[left] == nums[mid] && nums[mid] == nums[right]){
for(int i = left; i < right; ++i){//顺序查找
if(nums[i] > nums[i+1]) return nums[i+1];
}
return nums[left];
}
else if(nums[mid] <= nums[right]){
right = mid;
}else if(nums[mid] > nums[right]){
left = mid + 1;
}
}
return nums[left];
}
};