• <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() 算法
            實(shí)現(xiàn),也算是堆的另外一種形式。

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



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


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




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



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


            自定義類型重載 operator< 后,聲明對象時(shí)就可以只帶一個(gè)模板參數(shù)。
            但此時(shí)不能像基本類型這樣聲明
            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
            前來學(xué)習(xí)C++ 東西不錯(cuò)  回復(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流
            不錯(cuò)哦   回復(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   管理


            伊人 久久 精品| 国产精品一区二区久久| 久久精品国产清自在天天线| 色播久久人人爽人人爽人人片AV| 天天躁日日躁狠狠久久 | 91精品国产综合久久香蕉| 狠狠色丁香婷婷综合久久来来去 | 国内精品久久国产| 久久久青草青青亚洲国产免观| 99久久精品久久久久久清纯| 久久久一本精品99久久精品88| 国产美女久久久| 国内高清久久久久久| 激情综合色综合久久综合| 亚洲女久久久噜噜噜熟女| 久久se精品一区二区影院| 亚洲狠狠婷婷综合久久久久 | 久久涩综合| 91精品免费久久久久久久久| 蜜桃麻豆WWW久久囤产精品| 精品久久久久久久久久久久久久久| 亚洲精品午夜国产VA久久成人 | 热re99久久6国产精品免费| 日韩一区二区三区视频久久| 91精品观看91久久久久久| 国产午夜福利精品久久2021 | 久久无码人妻一区二区三区午夜| 久久99国产一区二区三区| 精品久久久久久国产| 午夜精品久久久久久中宇| 国产成人无码精品久久久性色| 久久久久久久国产免费看| 丰满少妇人妻久久久久久4| 国产91色综合久久免费| 欧美黑人又粗又大久久久| 久久久久亚洲精品日久生情 | 久久精品国产免费观看三人同眠| 久久伊人精品青青草原日本| 久久久久亚洲av成人无码电影| 国产精品女同一区二区久久| 免费国产99久久久香蕉|