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


            中文字幕人妻色偷偷久久| 2020最新久久久视精品爱| 久久久久亚洲av综合波多野结衣| 久久久久亚洲av成人网人人软件 | 久久精品午夜一区二区福利| 国产精品福利一区二区久久| 99久久国产亚洲高清观看2024| 午夜精品久久久久| 久久午夜羞羞影院免费观看 | 亚洲а∨天堂久久精品| 久久久久久精品成人免费图片| 婷婷伊人久久大香线蕉AV | 久久久久久国产精品美女| 国产精品久久久久影院色| 久久经典免费视频| 91麻豆精品国产91久久久久久| 久久亚洲国产成人影院| 国产巨作麻豆欧美亚洲综合久久| 亚洲乱码中文字幕久久孕妇黑人| 国产精品女同一区二区久久| 国产精品久久久久jk制服| 伊人久久大香线蕉AV一区二区| 青青草原1769久久免费播放| 久久99久久99精品免视看动漫| 久久久亚洲裙底偷窥综合| 久久久久18| 久久精品国产99久久香蕉| 亚洲国产二区三区久久| 精品免费久久久久久久| 午夜不卡久久精品无码免费| 亚洲va国产va天堂va久久| 人人狠狠综合久久亚洲高清| 国产精品免费久久久久电影网| 久久精品国产99国产精偷| 欧美精品久久久久久久自慰| 久久99久国产麻精品66| 国产精品久久久久久久人人看 | 午夜久久久久久禁播电影| 亚洲中文久久精品无码ww16| 久久精品国产久精国产一老狼| 色播久久人人爽人人爽人人片AV|