题解 | #旋转数组的最小数字#
旋转数组的最小数字
https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
* 查找依据都是以右值为基准;而不要一会左值,一会右值,这样就不能尽数考虑左右值
* 若将右值考虑清楚之后,也就等同考虑到了左值;
*
* @param nums int整型vector
* @return int整型
*/
int minNumberInRotateArray(vector<int>& nums) {
int left = 0;
int right = nums.size()-1;
while (left < right) { // 判断的依据都以右值为基准
auto mid = (left + right) / 2;
if (nums[mid] > nums[right])
left = mid + 1; // mid+1的情况
else if (nums[mid] == nums[right])
--right;
else
right = mid;
}
return nums[right];
}
};
