學(xué)習(xí)篇|leetcode刷題筆記-貪心篇

題型1、2個(gè)維度的要求

戰(zhàn)略:

不能顧此失彼,先從一個(gè)維度下手召夹,再解決另個(gè)維度的問題

典型例題:

? 135. 分發(fā)糖果
? 406. 根據(jù)身高重建隊(duì)列

題型2滥嘴、區(qū)間問題

戰(zhàn)略:

先考慮如何排序动羽,根據(jù)排序后的結(jié)果貪心實(shí)現(xiàn)

典型例題:

? 452. 用最少數(shù)量的箭引爆氣球
? 435. 無重疊區(qū)間


以上本質(zhì)都是在求有幾個(gè)重疊區(qū)段

? 56. 合并區(qū)間
為什么不能按照右端排序句喷?
\color{green}{不能通過的案例({2,3},{4,5},{6,7},{8,9},{1,10})}

題型3镣典、763. 劃分字母區(qū)間

戰(zhàn)術(shù):

利用雙指針劃定當(dāng)前區(qū)間端

    public List<Integer> partitionLabels(String s) {
        int start = 0;
        int end = 0;
        int[] arr = new int[26];
        Arrays.fill(arr, -1);
        List<Integer> resultList = new ArrayList<>();
        for (int i=0; i<s.length(); ++i) {
            // 雙指針找到一組子字符串的end
            while (i<=end) {
                char ch = s.charAt(i);
                if (arr[ch-'a']==-1) {
                    // 找到當(dāng)前字符的end
                    int j = s.length()-1;
                    for (; j>=i; --j) {
                        if (s.charAt(j) == ch) {
                            break;
                        }
                    }
                    arr[ch-'a'] = j;
                }
                end = Math.max(end, arr[ch-'a']);
                i++; 
            }
            
            resultList.add(end-start+1);
            start = i;
            end = start;
            i--; 
        }

戰(zhàn)術(shù)改進(jìn):

因?yàn)槭?6個(gè)小寫字母,可以用26長度的int數(shù)組表示每個(gè)字母在字符串中最后的位置唾琼。其實(shí)雙指針也是 為了找到最后的字母位置兄春。但是這種方法限定了,必須提前知道字符串的范圍是哪些字符組成锡溯。


public List<Integer> partitionLabels(String s) {
        int[] position = new int[26];
        Arrays.fill(position, -1);
        char[] ch = s.toCharArray();
        for (int i=0; i<ch.length; ++i) {
            position[ch[i]-'a'] = i;
        }
        List<Integer> result = new ArrayList<>();
        int start = -1;
        int end = 0;
        for (int i=0; i<ch.length;++i) {
            end = Math.max(position[ch[i]-'a'], end);
            if (end == i) {
                result.add(end-start);
                start=end;
            }
        }
        return result;
}

題型4赶舆、738. 單調(diào)遞增的數(shù)字

戰(zhàn)術(shù):非貪心的做法

找到第一個(gè)不單調(diào)的位置,包括相等的祭饭,變?cè)撐恢脼楫?dāng)前數(shù)字-1芜茵,在該位置后面的變9。為方便處理倡蝙,數(shù)字要改字符串處理九串,這一點(diǎn)可以引申,以后遇到類似問題注意處理寺鸥。

public int monotoneIncreasingDigits(int n) {
        String[] strings = (n+"").split("");
        int[] position = new int[10];
        Arrays.fill(position, -1);
        int start = -1;
        for (int i=0; i<strings.length; ++i) {
            int num = Integer.parseInt(strings[i]);
            if (position[num] == -1){
              position[num] = i;
            }

            if (i>0){
                int a = Integer.parseInt(strings[i-1]);
                int b = Integer.parseInt(strings[i]);
                if (a>b) {
                    start = position[a];
                    break;
                }
            }
        }
        if (start==-1) {
            return n;
        } else {
            strings[start] = (Integer.parseInt(strings[start])-1)+"";
            for (int i=start+1; i<strings.length; ++i) {
                strings[i] = "9";
            }
        }
        return Integer.parseInt(String.join("",strings));
    }

戰(zhàn)術(shù)改進(jìn):找到第一個(gè)不單調(diào)的位置猪钮,并不容易,代碼也比較冗長析既,同時(shí)使用了position保存數(shù)字首次出現(xiàn)的位置躬贡,內(nèi)存消耗高。如何改進(jìn)眼坏?
逆向遍歷拂玻,如果nums[i]<nums[i-1], 記錄i的位置,同時(shí)nums[i-1]-1宰译。

public int monotoneIncreasingDigits(int n) {
        String[] strings = (n + "").split("");
        int start = strings.length;
        for (int i = strings.length - 1; i > 0; i--) {
            if (Integer.parseInt(strings[i]) < Integer.parseInt(strings[i - 1])) {
                strings[i - 1] = (Integer.parseInt(strings[i - 1]) - 1) + "";
                start = i;
            }
        }
        for (int i=start; i<strings.length; ++i) {
            strings[i] = "9";
        }

        return Integer.parseInt(String.join("",strings));
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末檐蚜,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子沿侈,更是在濱河造成了極大的恐慌闯第,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缀拭,死亡現(xiàn)場(chǎng)離奇詭異咳短,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)蛛淋,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門咙好,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人褐荷,你說我怎么就攤上這事勾效。” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵层宫,是天一觀的道長杨伙。 經(jīng)常有香客問我,道長萌腿,這世上最難降的妖魔是什么限匣? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮哮奇,結(jié)果婚禮上膛腐,老公的妹妹穿的比我還像新娘睛约。我一直安慰自己鼎俘,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布辩涝。 她就那樣靜靜地躺著贸伐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪怔揩。 梳的紋絲不亂的頭發(fā)上捉邢,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音商膊,去河邊找鬼伏伐。 笑死,一個(gè)胖子當(dāng)著我的面吹牛晕拆,可吹牛的內(nèi)容都是我干的藐翎。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼实幕,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼吝镣!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起昆庇,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤末贾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后整吆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拱撵,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年表蝙,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拴测。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡勇哗,死狀恐怖昼扛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤抄谐,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布渺鹦,位于F島的核電站,受9級(jí)特大地震影響蛹含,放射性物質(zhì)發(fā)生泄漏毅厚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一浦箱、第九天 我趴在偏房一處隱蔽的房頂上張望吸耿。 院中可真熱鬧,春花似錦酷窥、人聲如沸咽安。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽妆棒。三九已至,卻和暖如春沸伏,著一層夾襖步出監(jiān)牢的瞬間糕珊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工毅糟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留红选,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓姆另,卻偏偏與公主長得像喇肋,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子蜕青,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • leetcode熱題 HOT 100第二部分題解苟蹈,按照題目序號(hào)排列。 二叉樹的層序遍歷 正常的層序遍歷操作即可右核,但...
    周飛飛飛機(jī)閱讀 986評(píng)論 0 1
  • 這里是 HOT 100刷題筆記慧脱,篇幅較長,因此分成兩部分贺喝,按照題目序號(hào)排列菱鸥。有幾題沒做后序會(huì)補(bǔ)上。 兩數(shù)之和 比較...
    周飛飛飛機(jī)閱讀 4,413評(píng)論 0 2
  • 貪心算法(又稱貪婪算法)是指躏鱼,在對(duì)問題求解時(shí)氮采,總是做出在當(dāng)前看來是最好的選擇。也就是說染苛,不從整體最優(yōu)上加以考慮鹊漠,他...
    奔跑吧李博閱讀 822評(píng)論 0 9
  • 思路總結(jié) 數(shù)組: 數(shù)組內(nèi)順序: 是否有序主到? 如果排序,是否會(huì)有額外的性質(zhì)躯概? 遞增登钥、遞減在該題內(nèi)的含義? prefi...
    童言銅鹽閱讀 1,152評(píng)論 0 0
  • 區(qū)間dp降低時(shí)間復(fù)雜度 給你一個(gè)字符串 s 娶靡,找出其中最長的回文子序列牧牢,并返回該序列的長度。子序列定義為:不改變剩...
    Cipolee閱讀 270評(píng)論 0 0