Meeting Rooms II解題報告

Description:

Given an array of meeting time intervals consisting of start and end times [[s1,e1],[s2,e2],...] (si < ei), find the minimum number of conference rooms required.

Example:

For example,
Given [[0, 30],[5, 10],[15, 20]],
return 2.

Link:

https://leetcode.com/problems/meeting-rooms-ii/description/

解題方法:

先記錄每個interval開始和結(jié)束所需要的房間數(shù),當(dāng)開始時,需要的房間數(shù)為1,而結(jié)束時,需要的房間數(shù)為-1;
再遍歷一遍以上記錄的數(shù)組,這樣所需的房間數(shù)會隨著以上的記錄不斷的變化,用一個變量去記錄隨時變化的房間數(shù)出現(xiàn)的最大值就是我們所求的值。

Tips:

用map作為儲存結(jié)構(gòu),就會按照時間的先后來儲存每個時間點(diǎn)需要的房間數(shù)。

Time Complexity:

因?yàn)閙ap的遍歷并不是O(N),所以時間為O(NlogN)。

完整代碼:

int minMeetingRooms(vector<Interval>& intervals) 
    {
        map<int, int> hash;
        for(auto a: intervals)
        {
            hash[a.start]++;
            hash[a.end]--;
        }
        int currRoom = 0, maxRoom = 0;
        for(auto a: hash)
        {
            currRoom += a.second;
            maxRoom = currRoom > maxRoom ? currRoom : maxRoom;
        }
        return maxRoom;
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,890評論 0 33
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,506評論 19 139
  • **2014真題Directions:Read the following text. Choose the be...
    又是夜半驚坐起閱讀 11,008評論 0 23
  • 好久沒有喝這么多了,今天竟然喝了1斤多的白酒,明明已經(jīng)要戒酒了,但是還是放縱自己去喝酒。摘下眼鏡,世界變的模糊了。...
    OO碰到OO閱讀 377評論 0 0
  • 有關(guān)定位(http://www.houdepeixun.com/)的戰(zhàn)爭在《中國企業(yè)如何定戰(zhàn)略——兼論麥肯錫戰(zhàn)略之...
    花花花17閱讀 201評論 0 0

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