旋轉(zhuǎn)數(shù)組的最小數(shù)字

題目描述

把一個(gè)數(shù)組最開(kāi)始的若干個(gè)元素搬到數(shù)組的末尾,我們稱(chēng)之為數(shù)組的旋轉(zhuǎn)。

輸入一個(gè)非遞減排序的數(shù)組的一個(gè)旋轉(zhuǎn),輸出旋轉(zhuǎn)數(shù)組的最小元素。

NOTE:給出的所有元素都大于0,若數(shù)組大小為0,請(qǐng)返回0。


思路:

由于旋轉(zhuǎn)數(shù)組是排過(guò)序的數(shù)組,因此,遍歷數(shù)組時(shí),數(shù)組的一開(kāi)始必然是遞增的,只需要保證數(shù)組一直遞增,或者不變,并一直記錄這個(gè)遞增數(shù)組中的最大值,一旦有數(shù)組小于這個(gè)數(shù)字,就證明,這是被調(diào)換位置的那幾個(gè)數(shù)字,返回第一個(gè)數(shù)字就是整個(gè)數(shù)組的最小值。

import java.util.ArrayList;

public class Solution {

? ? public int minNumberInRotateArray(int [] array)

? ? {

? ? ? ? int i=0;

? ? ? ? int x=0;

? ? ? ? while(true)

? ? ? ? {

? ? ? ? ? ? if(array.length==0)

? ? ? ? ? ? {

? ? ? ? ? ? ? ? return 0;

? ? ? ? ? ? }

? ? ? ? ? ? if(array.length==1)

? ? ? ? ? ? {

? ? ? ? ? ? ? ? return array[0];

? ? ? ? ? ? }


? ? ? ? ? ? if(x<=array[i])

? ? ? ? ? ? {

? ? ? ? ? ? ? x=array[i];

? ? ? ? ? ? ? i++;


? ? ? ? ? ? }

? ? ? ? ? ? if(x>array[i])

? ? ? ? ? ? {

? ? ? ? ? ? ? ? return array[i];

? ? ? ? ? ? }

? ? ? ? }

? ? }

}

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

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

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