一起學(xué)算法-435. 無重疊區(qū)間

一裙戏、題目435. 無重疊區(qū)間

LeetCode地址:https://leetcode-cn.com/problems/non-overlapping-intervals/
難度:中等
給定一個(gè)區(qū)間的集合卿堂,找到需要移除區(qū)間的最小數(shù)量,使剩余區(qū)間互不重疊。
注意:
可以認(rèn)為區(qū)間的終點(diǎn)總是大于它的起點(diǎn)箍铲。
區(qū)間 [1,2] 和 [2,3] 的邊界相互“接觸”冻押,但沒有相互重疊。

示例 1:

輸入: [ [1,2], [2,3], [3,4], [1,3] ]
輸出: 1
解釋: 移除 [1,3] 后鳞陨,剩下的區(qū)間沒有重疊昨寞。

示例 2:

輸入: [ [1,2], [1,2], [1,2] ]
輸出: 2
解釋: 你需要移除兩個(gè) [1,2] 來使剩下的區(qū)間沒有重疊。

示例 3:

輸入: [ [1,2], [2,3] ]
輸出: 0
解釋: 你不需要移除任何區(qū)間厦滤,因?yàn)樗鼈円呀?jīng)是無重疊的了援岩。

二、解題思路

先把區(qū)間按照結(jié)尾的大小進(jìn)行升序排序掏导,找到數(shù)組end中的最小值享怀。用end值與數(shù)組start相互比較,保留符合的區(qū)間趟咆。按照這個(gè)策略比較添瓷,找到符合的區(qū)間。

三值纱、實(shí)現(xiàn)過程

c++

class Solution {
public:
    int eraseOverlapIntervals(vector<vector<int>>& intervals) {
        if (intervals.empty()) {
            return 0;
        }
        int n = intervals.size();
        sort(intervals.begin(), intervals.end(), [](vector<int>& a, vector<int>& b){
            return a[1] < b[1];
        });
        int total = 0, prev = intervals[0][1];
        for (int i = 1; i < n; ++i) {
            if (intervals[i][0] < prev) {
                ++total;
            } else {
                prev = intervals[i][1];
            }
        }
        return total;
    }
};

PHP方法一

class Solution {

    /**
     * @param Integer[][] $intervals
     * @return Integer
     */
    function eraseOverlapIntervals($intervals) {
        //處理簡(jiǎn)單情況
        $len = count($intervals);
        if($len < 2){
            return 0;
        }
        //按照區(qū)間開始位置升序排列
        for($i = 0; $i < $len - 1 ;$i++){
            for($j = $i + 1;$j < $len;$j++){
                if($intervals[$i][1] > $intervals[$j][1]){
                    $temp = $intervals[$i];
                    $intervals[$i] = $intervals[$j];
                    $intervals[$j] = $temp;
                }
            }
        }
        //計(jì)算法結(jié)果
        $total = 0;
        $prev = $intervals[0][1];
        for($i = 1; $i < $len;$i++){
            if($prev > $intervals[$i][0]){
                ++$total;
            }else{
                $prev = $intervals[$i][1];
            }
        }
        return $total;
    }
}

PHP方法二

class Solution {

    /**
     * @param Integer[][] $intervals
     * @return Integer
     */
    function eraseOverlapIntervals($intervals) {
        array_multisort($intervals);
        $w = array_column($intervals,0);
        $h = array_column($intervals,1);
        $end = $h[0];
        $len = count($w);
        for($i=1;$i<$len;$i++){
            if($w[$i]<$end){
                unset($w[$i]);
            }else{
                $end = min(array_slice($h,$i));
            }
        }
        $count = count($h)-count($w);
        return $count;
    }
}

PS:方法二來自網(wǎng)友的解法鳞贷,那么問題來了兩種方法差距為什么這么大?尤其方法一居然比js慢那么多。虐唠。搀愧。


Snipaste_2021-04-29_23-12-30.png
Snipaste_2021-04-29_23-13-18.png

JavaScript

/**
 * @param {number[][]} intervals
 * @return {number}
 */
var eraseOverlapIntervals = function(intervals) {
    var len = intervals.length;
    if(len  < 2){
        return 0;
    }
    
    for(var i = 0; i < len - 1 ;i++){
        for(var j = i + 1;j < len;j++){
            if(intervals[i][1] > intervals[j][1]){
                temp = intervals[i];
                intervals[i] = intervals[j];
                intervals[j] = temp;
            }
        }
    }
    
    var total = 0;
    var prev = intervals[0][1];
    for(var i = 1; i < len;i++){
        if(prev > intervals[i][0]){
            ++total;
        }else{
            prev = intervals[i][1];
        }
    }
    return total;
    
};

三、小結(jié)

同樣的算法疆偿,php與js的差距我不得不懷疑php對(duì)二維數(shù)組的支持真的不太友好妈橄。
Javascript排序可通“intervals.sort((a,b)=>a[1] - b[1]);”直接實(shí)現(xiàn),那么php有沒有什么好的方法翁脆?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末眷蚓,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子反番,更是在濱河造成了極大的恐慌沙热,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罢缸,死亡現(xiàn)場(chǎng)離奇詭異篙贸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)枫疆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門爵川,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人息楔,你說我怎么就攤上這事寝贡“桥” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵圃泡,是天一觀的道長(zhǎng)碟案。 經(jīng)常有香客問我,道長(zhǎng)颇蜡,這世上最難降的妖魔是什么价说? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮风秤,結(jié)果婚禮上鳖目,老公的妹妹穿的比我還像新娘。我一直安慰自己缤弦,他們只是感情好领迈,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著甸鸟,像睡著了一般惦费。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抢韭,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天薪贫,我揣著相機(jī)與錄音,去河邊找鬼刻恭。 笑死瞧省,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鳍贾。 我是一名探鬼主播鞍匾,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼骑科!你這毒婦竟也來了橡淑?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤咆爽,失蹤者是張志新(化名)和其女友劉穎梁棠,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體斗埂,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡符糊,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了呛凶。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片男娄。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出模闲,到底是詐尸還是另有隱情建瘫,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布围橡,位于F島的核電站暖混,受9級(jí)特大地震影響缕贡,放射性物質(zhì)發(fā)生泄漏翁授。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一晾咪、第九天 我趴在偏房一處隱蔽的房頂上張望收擦。 院中可真熱鬧,春花似錦谍倦、人聲如沸塞赂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宴猾。三九已至,卻和暖如春叼旋,著一層夾襖步出監(jiān)牢的瞬間仇哆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來泰國(guó)打工夫植, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留讹剔,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓详民,卻偏偏與公主長(zhǎng)得像延欠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子沈跨,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

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