• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            原題地址
            本沙茶去年曾經用雙線段樹的方法捉了這題(詳見這里),最近重新審視這題發現,借助平衡樹,可以得到更簡單的方法。

            題目大意:
            有一個長度為N的內存條,每個位置的狀態有占用和不占用兩種,有4種操作:
            (1)Reset:清空所有內存(即將所有位置的狀態改為不占用,刪除所有內存塊);
            (2)New x:申請一個新的內存塊,即找到一個長度為x的連續不占用位置區間,將它們標記為占用,若有多個這樣的區間,取最左邊的,若木有輸出Reject New;
            (3)Free x:在已申請的內存塊中,找到包含位置x的并釋放(將該內存塊刪除,同時其占用的所有位置改為不占用),若木有內存塊包含位置x,則輸出Reject Free;
            (4)Get x:找出已申請的內存塊中,左起第x個,并輸出其左端點;若已申請的內存塊數目不足x個,則輸出Reject Get。

            可以發現,每個已經申請的內存塊盡管代表一段區間,但仍然是獨立的單位,因此,可以把內存塊當成結點,用平衡樹維護(關鍵字為內存塊的左端點位置),New操作中內存塊的插入與Free操作中內存塊的刪除均在此平衡樹內進行,Reset操作只需要將整棵樹銷毀即可。
            問題是,在New操作中,需要找到一個長度為x的連續不占用區間,而連續的不占用區間并不是獨立的單位,因此需要使用線段樹維護。在線段樹中,需要維護<1>結點區間內最長連續不占用塊的長度;<2>結點區間左端、右端連續不占用塊的長度(否則無法維護<1>);同時,由于在New操作中需要區間整體改占用,Free操作中又需要區間整體改不占用,所以應當支持整體改值的標記,對于Reset操作,只需要全部位置改不占用即可(不能重新建樹!!);

            這樣,利用一棵平衡樹加一棵線段樹,就可以得到一個很簡單的方法了(代碼量是雙平衡樹或雙線段樹的一半左右);

            這題的啟示是,在解決數據結構統計類題的時候,到底選用什么樣的數據結構,是有講究的,因為它將直接影響到編程復雜度。一般來說,線段樹比平衡樹好寫,但是對本題而言,雙線段樹反而不如平衡樹加線段樹好寫,這是因為對于內存塊使用平衡樹維護比使用線段樹維護更好。在以后做這種題的時候,要多想一下,找到簡便方法。
            日本精品久久久久影院日本| 精品久久8x国产免费观看| 亚洲午夜久久久久久噜噜噜| 91性高湖久久久久| 久久国产精品成人片免费| 国产色综合久久无码有码| 一级女性全黄久久生活片免费| 亚洲午夜久久影院| 国产产无码乱码精品久久鸭| 欧美一区二区三区久久综| 中文字幕久久精品无码| 亚洲成色WWW久久网站| 伊人久久综合成人网| 久久久久无码精品国产不卡| 亚洲av成人无码久久精品| AV无码久久久久不卡蜜桃| 亚洲色大成网站www久久九| 亚洲精品乱码久久久久久久久久久久 | 国产香蕉97碰碰久久人人| 97精品国产97久久久久久免费| 亚洲一区中文字幕久久| 久久久WWW免费人成精品| 亚洲国产精品狼友中文久久久| 国产69精品久久久久APP下载| 伊色综合久久之综合久久| 精品无码久久久久久午夜| 国产精品一区二区久久不卡| 国内精品伊人久久久久影院对白 | 久久精品国产免费观看| 色综合久久久久久久久五月| 激情伊人五月天久久综合| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 97精品久久天干天天天按摩| 青青青青久久精品国产h| 亚洲精品NV久久久久久久久久 | 久久久久久午夜成人影院| 免费精品99久久国产综合精品| 少妇被又大又粗又爽毛片久久黑人| 色8久久人人97超碰香蕉987| 国产99久久久久久免费看| 日韩av无码久久精品免费|