首页 > 编程语言 > 详细

剑指offer:旋转数组的最小数字

时间:2020-01-23 11:55:59      阅读:86      评论:0      收藏:0      [点我收藏+]

思路

  数组在一定程度上是排序的,很容易分析出:可以采用二分法来寻找最小数字

  如果数组的旋转是其本身,则最小数字是第一个数字

public class 旋转数组的最小数字 {
	public int minNumberInRotateArray(int [] array) {
		if(array.length==0){
			return 0;
		}
		if(array[0]<array[array.length-1]){
			return array[0];
		}
		
		int start = 0;
		int end = array.length-1;
		int flag = 0;
		//3 4 5 1 2
		while(start+1!=end){
			int mid = (start+end)/2;
			//向右靠拢
			if(array[mid]>array[start]){
				start = mid;
			}else if(array[mid]<array[end]){//向左靠拢
				end = mid;
			}else{
				start++;
			}
		}
		
		return array[end];
	}
}

  

剑指offer:旋转数组的最小数字

原文:https://www.cnblogs.com/blzm742624643/p/12230392.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!