• <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 閱讀(15782) 評論(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   管理


            久久久久综合网久久| 91精品国产91久久久久久青草 | 俺来也俺去啦久久综合网| 久久人人爽人人爽人人AV东京热| 久久99久久99小草精品免视看| 久久国产精品一区| 久久精品水蜜桃av综合天堂| 青青青青久久精品国产| 人妻精品久久久久中文字幕69| 99热都是精品久久久久久| 无码乱码观看精品久久| 91精品国产高清久久久久久国产嫩草| 久久福利资源国产精品999| 亚洲一本综合久久| 久久精品国产亚洲AV嫖农村妇女| 日韩欧美亚洲综合久久影院Ds| 日韩精品久久久久久| 色88久久久久高潮综合影院| 亚洲综合久久夜AV | 欧美大战日韩91综合一区婷婷久久青草 | 思思久久99热免费精品6| 93精91精品国产综合久久香蕉| 色偷偷88888欧美精品久久久| 久久精品免费网站网| 国产精品日韩深夜福利久久| avtt天堂网久久精品| 国内精品伊人久久久久AV影院| 久久亚洲私人国产精品vA| 久久婷婷五月综合成人D啪 | 午夜人妻久久久久久久久| 久久久久久精品成人免费图片 | 久久久婷婷五月亚洲97号色| 久久九九兔免费精品6| 精品久久久久久国产| 人妻无码久久一区二区三区免费| 一本一道久久综合狠狠老| 久久久久久久久波多野高潮| 97精品依人久久久大香线蕉97| 久久久久久亚洲Av无码精品专口| 亚洲精品午夜国产VA久久成人| 国产精品久久午夜夜伦鲁鲁|