• <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 調(diào)用 STL里面的 make_heap(), pop_heap(), push_heap() 算法
            實現(xiàn),也算是堆的另外一種形式。

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



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


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




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



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


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

            例子:


             

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

            評論:
            # re: priority_queue用法 2009-06-24 17:26 | superlong
            前來學(xué)習(xí)C++ 東西不錯  回復(fù)  更多評論
              
            # re: priority_queue用法 2009-06-26 18:30 | gnaggnoyil
            騷啊......寫Pascal還得自己寫......  回復(fù)  更多評論
              
            # re: priority_queue用法 2009-10-26 18:27 | huangzhifei
            好東西,牛B
            Orz
            …………  回復(fù)  更多評論
              
            # re: priority_queue用法 2011-05-21 10:56 | l流
            不錯哦   回復(fù)  更多評論
              
            # re: priority_queue用法 2011-12-20 22:05 | zz_lizhen
            好文章!對我很有幫助!學(xué)習(xí)了。  回復(fù)  更多評論
              
            # re: priority_queue用法 2012-12-05 07:02 | S.飛翔
            謝謝,很有幫助  回復(fù)  更多評論
              
            # re: priority_queue用法 2012-12-11 15:18 | abc
            贊!  回復(fù)  更多評論
              

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久99毛片免费观看不卡| 欧美伊人久久大香线蕉综合| 亚洲级αV无码毛片久久精品| 精品国产99久久久久久麻豆| 青青草原精品99久久精品66| 国产成人久久久精品二区三区| 亚洲成av人片不卡无码久久| 久久精品免费一区二区| 一本伊大人香蕉久久网手机| 污污内射久久一区二区欧美日韩| 久久久久亚洲av无码专区| 久久久艹| 91精品国产综合久久四虎久久无码一级| 久久久国产精华液| 国产亚洲欧美成人久久片| 成人久久免费网站| 久久久久一本毛久久久| 久久综合国产乱子伦精品免费| 久久精品国产亚洲Aⅴ香蕉| 欧美大香线蕉线伊人久久| 久久久精品日本一区二区三区 | 漂亮人妻被黑人久久精品| 国产精品久久久99| 久久99国产精品一区二区| 久久人人爽人人爽人人片AV麻烦| 久久成人精品| 久久精品国产色蜜蜜麻豆| 亚洲欧美日韩精品久久| 国内精品久久国产大陆| 久久夜色精品国产噜噜麻豆| 99蜜桃臀久久久欧美精品网站 | 三上悠亚久久精品| 欧美伊人久久大香线蕉综合| 亚洲欧洲中文日韩久久AV乱码| 久久99亚洲综合精品首页| 国产农村妇女毛片精品久久| 久久这里只精品国产99热| 一本色道久久88加勒比—综合| 老司机国内精品久久久久| 91超碰碰碰碰久久久久久综合| 久久96国产精品久久久|