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

             

            template<typename Type>
            struct Great{
                
            bool operator()( Type  a, Type  b ){
                    
            return a> b; }
            };

            template
            <typename Type>
            struct Less{
                
            bool operator()( Type const& a, Type const& b ){
                    
            return a< b; }
            };

            #define SIZE  10010

            template
            <typename Type, typename Cmp>
            class priority_queue{
                
            private:
                    Type d[SIZE];
                    
                
            public:
                    
            void push( Type const& item ){
                        
            int pos= ++*d; 
                        
            while( pos>>1 >= 1 && Cmp()( d[pos>>1], item ) ) 
                        d[pos]
            = d[pos>>1], pos>>=1;
                        d[pos]
            = item;
                    }
                    
            void pop(){
                        Type tmp
            = d[d[0]--]; int p= 1
                        
            forint q= p<<1; q<= *d; q<<= 1 ){
                            
            if( q+ 1<= *&& !Cmp()( d[q+1], d[q] ) ) q++;
                            
            if!Cmp()( tmp, d[q] ) ) break;
                            d[p]
            = d[q];  p= q;
                        }
                        d[p]
            = tmp;
                    }    
                    priority_queue(){ 
            *d= 0; }    
                    Type top()  { 
            return d[1];   }
                    
            int  size() { return *d;     }
                    
            bool empty(){ return *d== 0; }
                    
            void clear(){ *d= 0;         }
            };

            //   聲明為 priority_queue<Type, Great<Type> > test 時(shí)為小頂堆
            //   聲明為 priority_queue<Type, Less<Type> > test 時(shí)為大頂堆 
            posted on 2009-04-20 18:28 Darren 閱讀(887) 評(píng)論(0)  編輯 收藏 引用

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


            欧美黑人激情性久久| 国内精品久久久久久久97牛牛| 久久精品国产99国产精品澳门| 久久精品国产亚洲av高清漫画| 久久免费的精品国产V∧| 97久久综合精品久久久综合| 精品国产99久久久久久麻豆| 久久99热只有频精品8| 久久国产热这里只有精品| 久久综合亚洲鲁鲁五月天| 99久久99久久精品免费看蜜桃| 国产精品久久永久免费| 久久91精品久久91综合| 青青青国产成人久久111网站| 久久91精品国产91| 国内精品久久久久影院免费| 超级97碰碰碰碰久久久久最新| 伊人久久精品线影院| 五月丁香综合激情六月久久| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久国语露脸国产精品电影| 国产激情久久久久影院老熟女免费 | 久久99精品国产麻豆蜜芽| 久久人人爽人人爽人人AV| 久久无码人妻精品一区二区三区 | 7777精品伊人久久久大香线蕉| 久久精品成人免费网站| 色欲av伊人久久大香线蕉影院| 久久久久这里只有精品 | 久久婷婷五月综合成人D啪| 嫩草影院久久国产精品| 四虎国产精品免费久久5151| 色狠狠久久AV五月综合| 久久精品国产免费观看三人同眠| 国内精品久久久久影院网站| 91精品国产色综久久| 亚洲午夜精品久久久久久人妖| 狠狠色婷婷综合天天久久丁香| 91久久婷婷国产综合精品青草| 香蕉久久夜色精品升级完成| 久久人人爽人人爽人人AV东京热|