• <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>

            單調隊列,顧名思義就是具有單調性的隊列O(∩_∩)O~,一般的隊列只能從隊尾入隊、隊首出隊;為了保持單調隊列的單調性,單調隊列除具有這兩種性質外,還可以從隊尾出隊。
            以單增的單調隊列為例,當元素t要入隊時,先要從隊尾依次彈出所有>=t的元素,再將t加在隊尾。
            舉個例子,如果序列:1 3 -1 -3 10要構成單調隊列,
            先將元素“1”放入隊列中,以初始化隊列,
            接著元素“3”要入隊,隊尾元素“1”比“3”小,因此“3”可以直接入隊,隊列變為1 3,
            接著“-1”要入隊,從隊尾依次彈出元素“3”“1”后將“-1”入隊,隊列變為-1,
            同理“-3”入隊后,隊列變為-3,
            “10”入隊后,隊列變為-3 10

            單調隊列有什么用呢?看一道例題:(poj2823)
            給定含有n個元素的無序序列a[],和一個整數k,要求求出a[]中每連續k個元素組成的序列中的最小值(或最大值),這樣的值可能有1個或n-k+1個。
            比較簡單的方式,是每次都將k個數排序后輸出最值,具有O(N^2logN)的時間復雜度。但如果用單調隊列的話,我們可以在O(N)的時間內求解,原因是每個元素最多入隊一次、出隊一次。
            要解決該題,我們還要記錄每個元素在原序列中的位置p,每次只需從隊首開始找到跟當前元素a[i]距離不大于k的元素(即是i-p+1<=k)輸出即可。
            以下是zoj2823的部分代碼,只寫出了最小值的情況,最大值大的家自己想吧。


            posted on 2012-07-19 12:21 小鼠標 閱讀(5505) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            • 1.?re: 線段樹
            • 是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
              加油,祝你好運啦!
            • --小鼠標
            • 2.?re: 線段樹
            • 對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
            • --傷心的筆
            • 3.?re: poj1273--網絡流
            • 過來看看你。
            • --achiberx
            • 4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
            • 膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
            • --Hang
            • 5.?re: 快速排序、線性時間選擇
            • 博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
            • --lsxqw2004

            閱讀排行榜

            久久综合鬼色88久久精品综合自在自线噜噜 | 无码国内精品久久人妻蜜桃| 久久久这里只有精品加勒比| 久久久无码精品亚洲日韩按摩| 国产精品美女久久久免费| 伊人久久综合无码成人网| 97精品伊人久久久大香线蕉| 97久久婷婷五月综合色d啪蜜芽| 伊人久久综在合线亚洲2019| 亚洲中文久久精品无码ww16| 久久精品综合一区二区三区| 久久国产色AV免费观看| 无码任你躁久久久久久| 伊人久久免费视频| 97超级碰碰碰久久久久| 国内精品九九久久精品| 亚洲精品NV久久久久久久久久 | 久久精品黄AA片一区二区三区| 久久人妻少妇嫩草AV无码蜜桃| 亚洲国产另类久久久精品黑人| 久久久久久无码国产精品中文字幕| 精品久久久久香蕉网| 欧美一区二区三区久久综合| 久久久亚洲AV波多野结衣 | 久久精品国产亚洲AV不卡| 亚洲国产成人久久综合一区77| 国产成人久久精品麻豆一区| 国产V亚洲V天堂无码久久久| 久久夜色精品国产噜噜噜亚洲AV| 伊人色综合九久久天天蜜桃| 久久国产AVJUST麻豆| 亚洲精品乱码久久久久久不卡| 热久久国产欧美一区二区精品| 久久精品亚洲男人的天堂| 欧美午夜精品久久久久久浪潮| 狠狠久久综合| 亚洲国产日韩综合久久精品| 三级三级久久三级久久 | 日本久久久久久中文字幕| 国产精品久久久久久一区二区三区| 久久久久久久亚洲Av无码|