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


            欧美亚洲国产精品久久| 亚洲天堂久久精品| 无码人妻精品一区二区三区久久| 久久亚洲精品人成综合网| 日本道色综合久久影院| 久久国内免费视频| 51久久夜色精品国产| 亚洲午夜久久久影院伊人| 久久综合成人网| 久久精品国产亚洲综合色| 亚洲中文字幕无码久久综合网 | 色99久久久久高潮综合影院| 亚洲中文久久精品无码ww16| 久久国产免费| 久久99精品九九九久久婷婷| 精品国产一区二区三区久久| 无码AV中文字幕久久专区| 国产精品一区二区久久精品涩爱| 久久99精品国产99久久6男男| 一本色道久久综合狠狠躁| 久久精品亚洲乱码伦伦中文| 久久久久国产一级毛片高清版| 久久天堂AV综合合色蜜桃网| 99精品久久精品一区二区| 久久久国产视频| 中文字幕精品无码久久久久久3D日动漫| 日韩精品久久久久久| 韩国三级大全久久网站| 久久96国产精品久久久| AV狠狠色丁香婷婷综合久久| 69国产成人综合久久精品| 久久国产色AV免费观看| 国产一级做a爰片久久毛片| 国产精品一区二区久久国产| 久久精品欧美日韩精品| 99久久99久久久精品齐齐 | 国产真实乱对白精彩久久| 狠狠色综合网站久久久久久久| 久久人人爽人人爽人人片AV麻豆 | 久久精品国产99久久香蕉| 99久久99久久精品国产片|