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

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

            HDOJ 2871 Memory Control 經典線段樹懶操作

            這題有點像Hotel的包裝版,非常經典,讓我進一步熟悉了線段樹的區(qū)間操作(主要是延遲標記的使用)。
            唯一的問題出在自己寫的二分函數(shù)上,死活都是TLE,后來參考了小HH的二分才過掉,不知道自己哪寫掛了,郁悶。。。。
            PS:順便問一下,高質量的內存管理難道真的是用線段樹實現(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時代表沒覆蓋
            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) 評論(0)  編輯 收藏 引用

            国产一区二区三精品久久久无广告| 性高朝久久久久久久久久| 久久久九九有精品国产| 色天使久久综合网天天| 欧洲国产伦久久久久久久| 久久婷婷人人澡人人爽人人爱| 日韩亚洲国产综合久久久| 中文字幕无码免费久久| 国内精品久久久久久久久电影网| 国产精品久久久天天影视| 一本一道久久综合狠狠老| 国内精品久久久久久野外| 精品国产福利久久久| 无码人妻久久一区二区三区蜜桃| 久久精品国产亚洲av影院| 国产精品久久网| 亚洲综合熟女久久久30p| 久久精品中文字幕有码| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久青青草视频| 久久久久亚洲AV片无码下载蜜桃| 久久综合中文字幕| 久久99精品久久只有精品| 久久亚洲综合色一区二区三区| 亚洲精品午夜国产VA久久成人| 久久免费的精品国产V∧| 一本色综合久久| 2021久久精品国产99国产精品| 久久国内免费视频| 亚洲日本va午夜中文字幕久久 | 久久精品国产男包| 亚洲精品高清一二区久久| 久久人妻少妇嫩草AV蜜桃| 亚洲午夜久久久久久噜噜噜| 色偷偷88欧美精品久久久 | 久久精品a亚洲国产v高清不卡| 7777久久久国产精品消防器材| 狠狠色狠狠色综合久久| 国产精品久久久久a影院| 久久婷婷五月综合成人D啪|