码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2020-01-23 12:45:13      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:剑指offer   highlight   二分   数组   个数   art   div   tar   数字   

思路

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

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

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:旋转数组的最小数字

标签:剑指offer   highlight   二分   数组   个数   art   div   tar   数字   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!