首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,小弟我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素

2012-09-01 
java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个

java-69-旋转数组的最小元素。把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素

public class MinOfShiftedArray {/** * Q69 旋转数组的最小元素 * 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。 * 例如数组{3, 4, 5, 1, 2}为{1, 2, 3, 4, 5}的一个旋转,该数组的最小值为1。 */public static void main(String[] args) {int[][] a={{1,2,3,4,5},{2,3,4,5,1},{3,4,5,1,2},{4,5,1,2,3},{5,1,2,3,4},};for(int[] each:a){int min=minOfShiftedArray(each);System.out.println(min);}}/* * Divide and conquer */public static int minOfShiftedArray(int[] x){if(x==null||x.length==0){return -1;}int len=x.length;int low=0;int high=len-1;if(x[low]<x[high]){//if the array is not shifted actually,e.g. {1,2,3,4,5}return x[low];}int mid=0;while(low<high){mid=(low&high)+(low^high)/2;if(mid==low){//if there are only two elements leftreturn x[low]<x[high]?x[low]:x[high];}if(x[mid]>x[low]){low=mid;}else{high=mid;}}return x[mid];}}

热点排行