• 【剑指offer】面试题 11. 旋转数组的最小数字


    面试题 11. 旋转数组的最小数字
    题目描述

    题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。
    例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 
    NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
    

    Java 实现
    复杂度:O(logN) + O(1)

    public class Solution {
        public int minNumberInRotateArray(int [] array) {
            if(array==null||array.length==0)
                return 0;
            int left = 0,right = array.length - 1;
            while(left<right){
                int mid = left + (right - left)/2;
                if(array[mid]<=array[right]){
                    right = mid;
                }else{
                    left = mid + 1;
                }
            }
            return array[left];
            
        	/*if(array==null||array.length==0)
                return 0;
        	Arrays.sort(array);
        	return array[0];
        	*/
        }
    }
    
  • 相关阅读:
    记录。短信网关.
    TP 笔记~
    FUCK IE FLASH(inline hook)
    API HOOK(MessageBoxA)
    inline hook MessageBox(2)
    c#线程中使用 dataset
    匈牙利算法解决二分图最大匹配
    C#:Array类的排序
    C#:属性
    C#:结构
  • 原文地址:https://www.cnblogs.com/hgnulb/p/9029579.html
Copyright © 2020-2023  润新知