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

            priority_queue 調用 STL里面的 make_heap(), pop_heap(), push_heap() 算法
            實現,也算是堆的另外一種形式。

            先寫一個用 STL 里面堆算法實現的與真正的STL里面的 priority_queue  用法相
            似的 priority_queue, 以加深對 priority_queue 的理解



            STL里面的 priority_queue 寫法與此相似,只是增加了模板及相關的迭代器什么的。


            priority_queue 對于基本類型的使用方法相對簡單。
            他的模板聲明帶有三個參數,priority_queue<Type, Container, Functional>
            Type 為數據類型, Container 為保存數據的容器,Functional 為元素比較方式。
            Container 必須是用數組實現的容器,比如 vector, deque 但不能用 list.
            STL里面默認用的是 vector. 比較方式默認用 operator< , 所以如果你把后面倆個
            參數缺省的話,優先隊列就是大頂堆,隊頭元素最大。
            看例子




            如果要用到小頂堆,則一般要把模板的三個參數都帶進去。
            STL里面定義了一個仿函數 greater<>,對于基本類型可以用這個仿函數聲明小頂堆
            例子:



             對于自定義類型,則必須自己重載 operator< 或者自己寫仿函數
            先看看例子:


            自定義類型重載 operator< 后,聲明對象時就可以只帶一個模板參數。
            但此時不能像基本類型這樣聲明
            priority_queue<Node, vector<Node>, greater<Node> >;
            原因是 greater<Node> 沒有定義,如果想用這種方法定義
            則可以按如下方式

            例子:


             

            posted on 2009-06-09 18:00 Darren 閱讀(15772) 評論(7)  編輯 收藏 引用

            評論:
            # re: priority_queue用法 2009-06-24 17:26 | superlong
            前來學習C++ 東西不錯  回復  更多評論
              
            # re: priority_queue用法 2009-06-26 18:30 | gnaggnoyil
            騷啊......寫Pascal還得自己寫......  回復  更多評論
              
            # re: priority_queue用法 2009-10-26 18:27 | huangzhifei
            好東西,牛B
            Orz
            …………  回復  更多評論
              
            # re: priority_queue用法 2011-05-21 10:56 | l流
            不錯哦   回復  更多評論
              
            # re: priority_queue用法 2011-12-20 22:05 | zz_lizhen
            好文章!對我很有幫助!學習了。  回復  更多評論
              
            # re: priority_queue用法 2012-12-05 07:02 | S.飛翔
            謝謝,很有幫助  回復  更多評論
              
            # re: priority_queue用法 2012-12-11 15:18 | abc
            贊!  回復  更多評論
              
            无码国内精品久久人妻蜜桃| 欧美精品一本久久男人的天堂| 久久99免费视频| 久久精品国产91久久综合麻豆自制| 精品综合久久久久久97超人| 国产精品成人99久久久久| 国产成人久久777777| 久久天天躁狠狠躁夜夜躁2014| 国产香蕉久久精品综合网| 欧美熟妇另类久久久久久不卡| 日韩欧美亚洲综合久久影院d3| 亚洲欧洲久久av| 国产精品对白刺激久久久| 久久高清一级毛片| 国产精品久久久久国产A级| 久久青青草视频| 91久久精品无码一区二区毛片| 波多野结衣久久一区二区| 久久国产精品久久国产精品| 久久综合久久美利坚合众国| 国产91久久综合| 精品久久久久久成人AV| 一本色综合久久| 国内精品久久久久久不卡影院| 精品久久久久久无码专区| 久久婷婷五月综合色奶水99啪| 99热成人精品免费久久| 三上悠亚久久精品| 久久九九兔免费精品6| 久久久受www免费人成| 一级做a爰片久久毛片16| 久久久久人妻一区二区三区vr| 欧美麻豆久久久久久中文| 囯产极品美女高潮无套久久久 | 久久精品人人做人人爽97| 伊人久久国产免费观看视频| 久久er国产精品免费观看2| 狠狠色婷婷久久一区二区三区 | 四虎影视久久久免费观看| 久久精品www| 国产高清美女一级a毛片久久w|