• <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 閱讀(881) 評(píng)論(0)  編輯 收藏 引用

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


            久久精品成人免费网站| 人人妻久久人人澡人人爽人人精品| 久久久久99精品成人片牛牛影视 | 97久久超碰成人精品网站| 伊人色综合久久| 久久婷婷人人澡人人爽人人爱| 91精品国产色综合久久| 2020最新久久久视精品爱| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 69国产成人综合久久精品| 免费国产99久久久香蕉| 亚洲国产欧洲综合997久久| 亚洲国产天堂久久综合网站| 日产久久强奸免费的看| 久久久久国产精品麻豆AR影院| 免费精品国产日韩热久久| 欧美成a人片免费看久久| 99热精品久久只有精品| 国产午夜精品理论片久久影视 | 久久99精品国产麻豆婷婷| 国产91久久精品一区二区| 日韩久久无码免费毛片软件| 亚洲中文字幕无码一久久区| 精品无码久久久久国产动漫3d | 色99久久久久高潮综合影院| 波多野结衣中文字幕久久| 久久综合给久久狠狠97色 | 国内精品久久久久久久coent| 少妇高潮惨叫久久久久久| 性做久久久久久久久老女人| 人人狠狠综合久久亚洲88| 久久久老熟女一区二区三区| 久久久久人妻一区精品色| 久久精品国产99久久丝袜| 成人国内精品久久久久影院VR| 久久精品亚洲精品国产色婷 | 蜜桃麻豆www久久| 韩国免费A级毛片久久| 日产精品久久久一区二区| 亚洲国产一成人久久精品| 久久久久亚洲av成人网人人软件|