题解 | #旋转数组的最小数字#
旋转数组的最小数字
https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param nums int整型vector
* @return int整型
*/
int minNumberInRotateArray(vector<int>& nums) {
// write code here
int left = 0;
int right = nums.size() - 1;
int mid;
while (left < right){
mid = (right - left) / 2 + left;
if (nums[mid] < nums[right]){ //-1会错过最小值,因为mid可能就是最小值
right = mid;
}else if (nums[mid] > nums[right]){ //不会错过最小值,因为mid不可能时最小值;不+1可能原地不动
left = mid + 1;
}else{ //不能确定mid在左侧还是右侧,但是right-1一定小于right
right--;
}
}
return nums[left];
}
};
查看8道真题和解析