【劍指offer】問題11:旋轉(zhuǎn)數(shù)組的最小數(shù)字

題目:把一個(gè)數(shù)組最開始的若干個(gè)元素搬到數(shù)組的末尾,我們稱之為數(shù)組的旋轉(zhuǎn)。輸入一個(gè)遞增排序的數(shù)組的一個(gè)旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)組的最小元素。

先上代碼。

    /**
     * 旋轉(zhuǎn)數(shù)組的最小數(shù)字
     */
    public int minNumberInRotateArray(int [] array) {
        if(array == null || array.length == 0)
            return -1;
        int index1 = 0;
        int index2 = array.length - 1;
        int indexMid = index1;
        while(array[index1] >= array[index2]){
            if(index2 - index1 == 1){
                indexMid = index2;
                break;
            }
            indexMid = (index1 + index2) / 2;
            if(array[index1] == array[indexMid] && array[indexMid] == array[index2]){
                return findMin(array, index1, index2);
            }
            if(array[index1] <= array[indexMid])
                index1 = indexMid;
            else if(array[index2] >= array[indexMid])
                index2 = indexMid;
        }
        return array[indexMid];

    }

    public int findMin(int[] arr, int start, int end){
        int min = arr[start];
        for(int i = start; i <= end; i++){
            if(arr[i] < min)
                min = arr[i];
        }
        return min;
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容