• <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)  編輯 收藏 引用

            MM131亚洲国产美女久久| 久久久久久国产精品免费免费| 国产成人精品久久亚洲| 综合久久精品色| 久久无码国产| 女同久久| 国产精品99久久久精品无码| 久久黄视频| 无码人妻少妇久久中文字幕 | 精品久久久无码中文字幕天天| 久久99精品久久久久久动态图| 久久综合噜噜激激的五月天| 亚洲精品乱码久久久久久自慰| 免费精品久久天干天干| 亚洲中文字幕无码一久久区| 无码AV波多野结衣久久| 国产成人精品免费久久久久| 久久精品国产精品亚洲精品| 精品水蜜桃久久久久久久| 久久久久99精品成人片| 精品久久久一二三区| 久久久久久综合网天天| 久久久久99精品成人片试看| 久久免费国产精品一区二区| 久久亚洲天堂| 久久亚洲春色中文字幕久久久| 嫩草影院久久国产精品| 深夜久久AAAAA级毛片免费看 | 97热久久免费频精品99| 国产69精品久久久久777| 久久国产精品久久| 免费一级做a爰片久久毛片潮| 亚洲午夜精品久久久久久app| 久久久www免费人成精品| 无码人妻久久久一区二区三区| 久久久无码一区二区三区| 久久精品嫩草影院| 日本久久中文字幕| 久久精品人人做人人爽电影| 国产精品美女久久久m| 国产成人精品久久亚洲|