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

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

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


            posted on 2012-07-19 12:21 小鼠標 閱讀(5505) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)
            <2012年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            閱讀排行榜

            久久无码av三级| 色天使久久综合网天天| 久久电影网一区| 精品99久久aaa一级毛片| 免费精品久久天干天干| 久久国产精品久久国产精品| 久久久久国产亚洲AV麻豆| 人妻无码久久一区二区三区免费 | 欧美一区二区久久精品| 久久99精品久久只有精品| 伊人 久久 精品| 国产无套内射久久久国产| 热re99久久6国产精品免费| 久久亚洲高清综合| 国产精品成人精品久久久| 久久这里只有精品18| 久久精品综合网| 日韩十八禁一区二区久久| 久久精品成人影院| 国产精品免费久久| 国产精品岛国久久久久| av无码久久久久久不卡网站| 久久亚洲sm情趣捆绑调教| 中文字幕久久精品| 欧美久久综合九色综合| 久久人人爽人人爽AV片| 热久久国产欧美一区二区精品| 国产亚洲婷婷香蕉久久精品| 久久久无码精品亚洲日韩按摩| 性欧美大战久久久久久久久| 中文字幕久久久久人妻| 精产国品久久一二三产区区别| 久久久久国产精品嫩草影院| 久久精品国产亚洲AV香蕉| 久久精品国产色蜜蜜麻豆| 影音先锋女人AV鲁色资源网久久| 中文字幕无码久久精品青草| 国内精品久久久久久久久电影网| 热久久视久久精品18| 久久精品天天中文字幕人妻| 国内精品久久久久久99|