劍指offer(6-10)

JZ6

問題描述:

把一個數(shù)組最開始的若干個元素搬到數(shù)組的末尾亲桥,我們稱之為數(shù)組的旋轉(zhuǎn)轩娶。輸入一個非遞減排序的數(shù)組的一個旋轉(zhuǎn)魄缚,輸出旋轉(zhuǎn)數(shù)組的最小元素暗甥。
例如數(shù)組[3,4,5,1,2]為[1,2,3,4,5]的一個旋轉(zhuǎn)喜滨,該數(shù)組的最小值為1。NOTE:給出的所有元素都大于0撤防,若數(shù)組大小為0虽风,請返回0。

思路:

  • 二分查找寄月,三個指針mid焰情、left、right
  • 如果中間值大于數(shù)組尾部的值剥懒,則left = mid + 1
  • 如果中間值小于尾部的值内舟,則right = mid
  • 如果中間值等于尾部的值,則直接讓右指針自減

代碼:

public class Solution {
    public int minNumberInRotateArray(int [] array) {
        if(array == null || array.length == 0) return 0;
        int n = array.length;
        int l = 0, r = n - 1; 
        while(l < r) {
            int m = (l + r) >> 1;
            if(array[m] > array[r]) {
                l = m + 1;
            }else if(array[m] < array[r]){
                r = m;
            }else{      // 相等的時候初橘,避免最小值在(m和r之間)验游,所以這個時候只能讓r--
                r--;
            }
        }
        return array[l];
    }
}

JZ7

問題描述:

大家都知道斐波那契數(shù)列,現(xiàn)在要求輸入一個整數(shù)n保檐,請你輸出斐波那契數(shù)列的第n項(從0開始耕蝉,第0項為0,第1項是1)夜只。n<=39

思路:

  • 動態(tài)規(guī)劃

代碼:

public class Solution {
    public int Fibonacci(int n) {
        if(n <= 1) return n;
        int p1 = 0, p2 = 1, c = 0;
        for(int i = 2; i <= n; i++) {
            c = p1 + p2;
            p1 = p2;
            p2 = c;
        }
        return c;
    }
}

JZ8

問題描述:

一只青蛙一次可以跳上1級臺階垒在,也可以跳上2級。求該青蛙跳上一個n級的臺階總共有多少種跳法(先后次序不同算不同的結(jié)果)扔亥。

思路一:

  • 動態(tài)規(guī)劃
  • 第n階臺階可能的狀態(tài)為第n-1階的可能方案加上第n-2階的可能方案

代碼:

public class Solution {
    public int JumpFloor(int target) {
        if (target <= 1) return target;
        int c0 = 1;
        int c1 = 1;
        int ans = 2;
        for (int i = 2; i <= target; i++) {
            ans = c0 + c1;
            c0 = c1;
            c1 = ans;
        }
        return ans;
    }
}

JZ9

問題描述:

一只青蛙一次可以跳上1級臺階场躯,也可以跳上2級……它也可以跳上n級。求該青蛙跳上一個n級的臺階總共有多少種跳法旅挤。

思路一:

  • 動態(tài)規(guī)劃
  • 第n階的可能方案為前面所有階層的方案累加和

代碼:

public class Solution {
    public int JumpFloorII(int target) {
        if(target == 1) return 1;
        int[] dp = new int[target + 1];
        dp[1] = 1;
        for(int i = 2; i <= target; i++) {
            for(int j = 1; j < i; j++) {
                dp[i] += dp[j];
            }
            dp[i]++;
        }
        return dp[target];
    }
}

JZ10

問題描述:

我們可以用2 * 1的小矩形橫著或者豎著去覆蓋更大的矩形踢关。請問用n個2 * 1的小矩形無重疊地覆蓋一個2 * n的大矩形,總共有多少種方法粘茄?

比如n = 3時签舞,2 * 3的矩形塊有3種覆蓋方法:

思路一:

  • 這道題可以轉(zhuǎn)化一種思路:
  • 你可以在1和2之間隨便取一個數(shù),給定一個整數(shù)n柒瓣,你的目標(biāo)就是找出取出來的數(shù)累加和為n一共有多少種可能性儒搭!
  • 例如:指定 n = 3, 可能的情況有1 1 1,1 2,2 1; 所以一共有3種可能的情況
  • 那么按照這個思路,一個dfs模板就可以解決問題了

代碼:

public class Solution {
    
    int res = 0;
    
    public int RectCover(int target) {
        if(target <= 2)return target;
        dfs(0, target);
        return res;
    }
    
    private void dfs(int cur, int sum) {
        if(cur > sum) return;
        if(cur == sum) {
            res++;
            return;
        }
        dfs(cur + 1, sum);
        dfs(cur + 2, sum);
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末芙贫,一起剝皮案震驚了整個濱河市搂鲫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌屹培,老刑警劉巖默穴,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怔檩,死亡現(xiàn)場離奇詭異褪秀,居然都是意外死亡蓄诽,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門媒吗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來仑氛,“玉大人,你說我怎么就攤上這事闸英【忉” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵甫何,是天一觀的道長出吹。 經(jīng)常有香客問我,道長辙喂,這世上最難降的妖魔是什么捶牢? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮巍耗,結(jié)果婚禮上秋麸,老公的妹妹穿的比我還像新娘。我一直安慰自己炬太,他們只是感情好灸蟆,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著亲族,像睡著了一般炒考。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上霎迫,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天票腰,我揣著相機(jī)與錄音,去河邊找鬼女气。 笑死杏慰,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的炼鞠。 我是一名探鬼主播缘滥,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼谒主!你這毒婦竟也來了朝扼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤霎肯,失蹤者是張志新(化名)和其女友劉穎擎颖,沒想到半個月后榛斯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡搂捧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年驮俗,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片允跑。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡王凑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出聋丝,到底是詐尸還是另有隱情索烹,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布弱睦,位于F島的核電站百姓,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏况木。R本人自食惡果不足惜垒拢,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望焦读。 院中可真熱鬧子库,春花似錦、人聲如沸矗晃。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽张症。三九已至仓技,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間俗他,已是汗流浹背脖捻。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留兆衅,地道東北人地沮。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像羡亩,于是被迫代替她去往敵國和親摩疑。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354