使用二分查找。
int findMin(vector<int>& nums)
{
int begin = 0, end = nums.size() - 1;
while(begin < end)
{
int mid = (begin + end) / 2;
if(mid == begin) // 只剩两个数的时候
return min(nums[begin], nums[end]);
if(nums[mid] > nums[end])
begin = mid;
else
end = mid;
}
return nums[begin];
}
本文介绍了一种使用二分查找算法寻找旋转排序数组中最小元素的方法。通过不断缩小搜索范围,该算法能在O(log n)的时间复杂度内找到目标值。
680

被折叠的 条评论
为什么被折叠?



