假设一个旋转排序的数组其起始位置是未知的(比如0 1 2 4 5 6 7 可能变成是4 5 6 7 0 1 2)。
返回 0
用二分法解决
二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好;其缺点是要求待查表为有序表,且插入删除困难。
public class Solution {
/**
* @param nums: a rotated sorted array
* @return: the minimum number in the array
*/
public int findMin(int[] nums) {
// write your code here
int begin = 0;
int end = nums.length - 1;
int mid;
if(nums[begin]<nums[end]){
return nums[begin];
}
while(begin < end){
mid = (begin+end)/2;
if(nums[mid]>nums[end])
begin = mid+1;
else
end = mid;
}
return nums[end];
}
}
本文介绍了一种在未知起始位置的旋转排序数组中寻找最小值的方法。利用二分查找法,通过比较中间元素与末尾元素来缩小搜索范围,最终高效地找到数组中的最小值。
375

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



