354. 俄羅斯套娃信封問題

354. 俄羅斯套娃信封問題 - 力扣(LeetCode)

信封的寬高為envelope的二維數(shù)組
寬為升序,寬相等時市殷,高為降序
envelopes[j][1] < envelopes[i][1] 為啥高維度比較的是1曙砂,不是0呢十偶,盗迟,數(shù)學沒學好啊延旧。二維數(shù)組 n行2列
// envelopes = [[w, h], [w, h]...]   
f[i]表示以 envelopes[i][1] 這個數(shù)結(jié)尾的最長遞增子序列的長度
class Solution {
    public int maxEnvelopes(int[][] envelopes) {
        if (envelopes.length == 0) {
            return 0;
        }
        
        int n = envelopes.length;
        Arrays.sort(envelopes, new Comparator<int[]>() {
            public int compare(int[] e1, int[] e2) {
                if (e1[0] != e2[0]) {
                    return e1[0] - e2[0];
                } else {
                    return e2[1] - e1[1];
                }
            }
        });

        int[] f = new int[n];
        Arrays.fill(f, 1);
        int ans = 1;
        for (int i = 1; i < n; ++i) {
            for (int j = 0; j < i; ++j) {
                if (envelopes[j][1] < envelopes[i][1]) {
                    f[i] = Math.max(f[i], f[j] + 1);
                }
            }
            ans = Math.max(ans, f[i]);
        }
        return ans;
    }
}

基于二分查找的動態(tài)規(guī)劃

class Solution {
    public int maxEnvelopes(int[][] envelopes) {
        if (envelopes.length == 0) {
            return 0;
        }
        
        int n = envelopes.length;
        Arrays.sort(envelopes, new Comparator<int[]>() {
            public int compare(int[] e1, int[] e2) {
                if (e1[0] != e2[0]) {
                    return e1[0] - e2[0];
                } else {
                    return e2[1] - e1[1];
                }
            }
        });

        List<Integer> f = new ArrayList<Integer>();
        f.add(envelopes[0][1]);
        for (int i = 1; i < n; ++i) {
            int num = envelopes[i][1];
            if (num > f.get(f.size() - 1)) {
                f.add(num);
            } else {
                int index = binarySearch(f, num);
                f.set(index, num);
            }
        }
        return f.size();
    }

    public int binarySearch(List<Integer> f, int target) {
        int low = 0, high = f.size() - 1;
        while (low < high) {
            int mid = (high - low) / 2 + low;
            if (f.get(mid) < target) {
                low = mid + 1;
            } else {
                high = mid;
            }
        }
        return low;
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末埋酬,一起剝皮案震驚了整個濱河市厌漂,隨后出現(xiàn)的幾起案子萨醒,更是在濱河造成了極大的恐慌,老刑警劉巖苇倡,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件富纸,死亡現(xiàn)場離奇詭異,居然都是意外死亡旨椒,警方通過查閱死者的電腦和手機晓褪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來综慎,“玉大人涣仿,你說我怎么就攤上這事∈揪” “怎么了好港?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長米罚。 經(jīng)常有香客問我媚狰,道長,這世上最難降的妖魔是什么阔拳? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任崭孤,我火速辦了婚禮类嗤,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘辨宠。我一直安慰自己遗锣,他們只是感情好,可當我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布嗤形。 她就那樣靜靜地躺著精偿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪赋兵。 梳的紋絲不亂的頭發(fā)上笔咽,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天,我揣著相機與錄音霹期,去河邊找鬼叶组。 笑死,一個胖子當著我的面吹牛历造,可吹牛的內(nèi)容都是我干的甩十。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼吭产,長吁一口氣:“原來是場噩夢啊……” “哼侣监!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起臣淤,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤橄霉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后邑蒋,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體酪劫,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年寺董,在試婚紗的時候發(fā)現(xiàn)自己被綠了覆糟。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡遮咖,死狀恐怖滩字,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情御吞,我是刑警寧澤麦箍,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站陶珠,受9級特大地震影響挟裂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜揍诽,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一诀蓉、第九天 我趴在偏房一處隱蔽的房頂上張望栗竖。 院中可真熱鬧,春花似錦渠啤、人聲如沸狐肢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽份名。三九已至,卻和暖如春妓美,著一層夾襖步出監(jiān)牢的瞬間僵腺,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工壶栋, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留辰如,地道東北人。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓委刘,卻偏偏與公主長得像丧没,于是被迫代替她去往敵國和親鹰椒。 傳聞我的和親對象是個殘疾皇子锡移,可洞房花燭夜當晚...
    茶點故事閱讀 44,713評論 2 354

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