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

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


            posted on 2012-07-19 12:21 小鼠標(biāo) 閱讀(5492) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)
            <2012年8月>
            2930311234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評(píng)論

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

            閱讀排行榜

            久久免费国产精品一区二区| 久久久久久伊人高潮影院| 精品国产青草久久久久福利| 三上悠亚久久精品| 狠狠狠色丁香婷婷综合久久五月| 久久香蕉一级毛片| 青青热久久国产久精品| 人人狠狠综合久久88成人| 亚洲国产精品久久久久婷婷老年| 久久亚洲AV无码精品色午夜麻豆 | 午夜精品久久久久久| 亚洲中文精品久久久久久不卡 | 日本高清无卡码一区二区久久| 亚洲精品乱码久久久久久蜜桃不卡| 久久精品国产亚洲av影院| 人妻丰满?V无码久久不卡| 狠狠色丁香婷婷久久综合不卡| 久久久久亚洲av综合波多野结衣| 久久777国产线看观看精品| 99蜜桃臀久久久欧美精品网站| 久久国产高清一区二区三区| 99精品久久精品| 精品国产99久久久久久麻豆| 久久99国产一区二区三区| 7777久久亚洲中文字幕| 亚洲精品乱码久久久久久蜜桃不卡| 久久国产精品视频| 久久亚洲高清观看| 国产精品久久自在自线观看| 一本一本久久a久久精品综合麻豆| 国产A级毛片久久久精品毛片| 久久精品无码午夜福利理论片| 青草国产精品久久久久久| 久久精品免费一区二区| 精品无码久久久久国产动漫3d| 国内精品久久久久影院亚洲| 久久婷婷色综合一区二区| 久久免费视频一区| 人人狠狠综合久久亚洲高清| 久久久午夜精品| 无码伊人66久久大杳蕉网站谷歌|