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

            The Fourth Dimension Space

            枯葉北風(fēng)寒,忽然年以殘,念往昔,語默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢(mèng)令

            HDOJ 2871 Memory Control 經(jīng)典線段樹懶操作

            這題有點(diǎn)像Hotel的包裝版,非常經(jīng)典,讓我進(jìn)一步熟悉了線段樹的區(qū)間操作(主要是延遲標(biāo)記的使用)。
            唯一的問題出在自己寫的二分函數(shù)上,死活都是TLE,后來參考了小HH的二分才過掉,不知道自己哪寫掛了,郁悶。。。。
            PS:順便問一下,高質(zhì)量的內(nèi)存管理難道真的是用線段樹實(shí)現(xiàn)的?
            #include<iostream>
            #include
            <algorithm>
            #include
            <vector>
            using namespace std;

            int const maxn=50010;
            int n,m;
            #define LL(i) (i<<1)
            #define RR(i) ((i<<1)|1)
            struct node
            {
                
            int l,r;
                
            int cval,lval,rval;
                
            int st;
                
            int len(){return r-l+1;}
                
            void doit()
                
            {
                    
            if(st==1)cval=lval=rval=0;
                    
            else cval=lval=rval=len();
                }

            }
            ST[maxn*8];

            struct block
            {
                
            int s,t;
            }
            ;
            vector
            <block>B;
            /*
            int Bfind(int x)//返回-1代表沒找到
            {
                int l=0;
                int r=B.size()-1;
                while(l<=r)
                {

                    int mid=(l+r)>>1;
                    if(x>=B[mid].s&&x<=B[mid].t)return mid;
                    if(x<B[mid].s)r=mid-1;
                    else if(x>B[mid].t)l=mid+1;
                }
                return -1;
            }


            int Infind(int x)//找到插入位置
            {
                int l=0;
                int r=B.size()-1;
                int len=B.size();

                while(l<=r)
                {    
                    if(x>B[len-1].t)
                        return B.size();
                    if(x<B[0].s)
                        return 0;
                    
                    int mid=(l+r)>>1;
                    if(x>B[mid].t&&x<B[mid+1].s)return mid+1;
                    if(x<B[mid].s) r=mid-1;
                    else if(x>B[mid].t)l=mid+1;
                    
                }
                   
            }
            */


            int Bin(int x) {
                
            int lo = 0;
                
            int hi =B.size()- 1;
                
            while(lo <= hi) {
                    
            int mid = (lo + hi) >> 1;
                    
            if(B[mid].s<= x) {
                        lo 
            = mid + 1;
                    }
             else {
                        hi 
            = mid - 1;
                    }

                }

                
            return lo;
            }

            //st為0時(shí)代表沒覆蓋
            void Build(int l,int r,int i)
            {
                ST[i].st
            =0;
                ST[i].l
            =l;
                ST[i].r
            =r;
                
            if(l==r){ST[i].cval=ST[i].lval=ST[i].rval=1;return;}
                
            int mid=(ST[i].l+ST[i].r)>>1;
                Build(l,mid,LL(i));
                Build(mid
            +1,r,RR(i));
                ST[i].cval
            =ST[i].lval=ST[i].rval=ST[i].len();
                
            }



            void update(int l,int r,int op,int i)
            {
                
            if(l==ST[i].l&&r==ST[i].r)
                
            {
                    ST[i].st
            =op;
                    ST[i].doit();
                    
            return;
                }

                
            if(ST[i].st!=-1)
                
            {
                    ST[LL(i)].st
            =ST[RR(i)].st=ST[i].st;
                    ST[LL(i)].doit();
                    ST[RR(i)].doit();
                    ST[i].st
            =-1;
                }

                
            int mid=(ST[i].l+ST[i].r)>>1;
                
            if(r<=mid)update(l,r,op,LL(i));
                
            else if(l>mid)update(l,r,op,RR(i));
                
            else{
                    update(l,mid,op,LL(i));
                    update(mid
            +1,r,op,RR(i));
                }

                ST[i].cval
            =max(ST[LL(i)].cval,ST[RR(i)].cval);
                ST[i].cval
            =max(ST[i].cval,ST[LL(i)].rval+ST[RR(i)].lval);
                
            //
                ST[i].lval=ST[LL(i)].lval;
                ST[i].rval
            =ST[RR(i)].rval;
                
            //
                if(ST[LL(i)].lval==ST[LL(i)].len())
                    ST[i].lval
            +=ST[RR(i)].lval;
                
            if(ST[RR(i)].rval==ST[RR(i)].len())
                    ST[i].rval
            +=ST[LL(i)].rval;
            }



            int Query(int w,int i)
            {
                
            if(ST[i].lval>=w)return ST[i].l;
                
            if(ST[i].st!=-1)
                
            {
                    ST[LL(i)].st
            =ST[RR(i)].st=ST[i].st;
                    ST[LL(i)].doit();
                    ST[RR(i)].doit();
                    ST[i].st
            =-1;
                }

                
            else if(ST[LL(i)].cval>=w)return Query(w,LL(i));
                
            else if(ST[LL(i)].rval+ST[RR(i)].lval>=w) return ST[LL(i)].r-ST[LL(i)].rval+1;
                
            else if(ST[RR(i)].cval>=w)return Query(w,RR(i));
                
            //else if(ST[RR(i)].rval>=w)return ST[RR(i)].r-ST[RR(i)].rval+1; 
                else return 0;
            }


            int main()
            {
                
            while(scanf("%d%d",&n,&m)!=EOF)
                
            {

                    Build(
            1,n,1);
                    B.clear();
                    
            for(int i=0;i<m;i++)
                    
            {
                        
            char op[9];
                        scanf(
            "%s",op);
                        
            if(op[0]=='N')
                        
            {
                        
                            
            int w;
                            scanf(
            "%d",&w);
                            
            if(ST[1].cval<w)
                                puts(
            "Reject New");
                            
            else
                            
            {
                            
                                
            //
                                int s=Query(w,1);
                                update(s,s
            +w-1,1,1);
                                printf(
            "New at %d\n",s);
                                
            //
                                block tem;
                                tem.s
            =s;
                                tem.t
            =s+w-1;
                                
            int pos=Bin(s);
                                B.insert(B.begin()
            +pos,tem);
                            }

                        }

                        
            else if(op[0]=='R')
                        
            {
                            update(
            1,n,0,1);
                            puts(
            "Reset Now");
                            B.clear();
                        }

                        
            else if(op[0]=='G')
                        
            {
                            
            int x;
                            scanf(
            "%d",&x);
                            
            if(x>B.size())
                                puts(
            "Reject Get");
                            
            else
                            
            {
                                printf(
            "Get at %d\n",B[x-1].s);
                            }


                        }

                        
            else
                        
            {
                            
            int x;

                            scanf(
            "%d",&x);
                            
            int t=Bin(x)-1;
                            
            if(t==-1||B[t].t<x)
                                puts(
            "Reject Free");
                            
            else
                            
            {
                                printf(
            "Free from %d to %d\n",B[t].s,B[t].t);
                                update(B[t].s,B[t].t,
            0,1);
                                B.erase(B.begin()
            +t,B.begin()+t+1);
                            }

                        }

                    }

                    puts(
            "");

                }



                
            return 0;
            }

            posted on 2010-10-30 20:00 abilitytao 閱讀(1676) 評(píng)論(0)  編輯 收藏 引用


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


            久久se精品一区精品二区| 99久久国产宗和精品1上映| 国产∨亚洲V天堂无码久久久 | 国内精品伊人久久久久影院对白| 久久精品国产一区| 一本大道久久东京热无码AV| 无码人妻久久一区二区三区免费| 久久香蕉国产线看观看99| 性高朝久久久久久久久久| 久久99国产综合精品免费| 亚洲v国产v天堂a无码久久| 久久久久久毛片免费播放| 亚洲欧美另类日本久久国产真实乱对白 | 日本国产精品久久| 国产亚洲综合久久系列| 亚洲国产日韩欧美综合久久| 久久99国产亚洲高清观看首页| 7777精品伊人久久久大香线蕉| 国产午夜精品久久久久九九电影 | 日本免费久久久久久久网站| 久久久久青草线蕉综合超碰| 欧美与黑人午夜性猛交久久久| 久久狠狠高潮亚洲精品| 无码人妻久久一区二区三区免费 | 无夜精品久久久久久| 99国产精品久久| 国内精品人妻无码久久久影院 | 久久无码AV一区二区三区| 久久影院久久香蕉国产线看观看| 久久精品国产亚洲AV无码娇色 | 久久天天躁夜夜躁狠狠| 蜜臀久久99精品久久久久久| 国内精品久久久久久久影视麻豆| 国产精品美女久久久久| 久久精品无码一区二区无码 | 漂亮人妻被黑人久久精品| 精品久久久中文字幕人妻| 久久精品人人做人人爽电影| 国产成人综合久久精品红| 久久人人爽人人爽人人片AV高清 | 国产亚洲美女精品久久久|