• 整理下线段树吧 poj hotel


    除了上次的新学的有 区间更新 延迟更新  区间合并

    先说下区间更新以及延迟更新吧

    既然是对区间的维护 在求解一些问题的时候 有的时候没有必要对所有的自区间都进行遍历 这个时候 延迟标记就派上用场了 (只有在需要的时候才对子区间更新)

    struct node()
    {
    int l,r,len;
    int flag=0;
    }stu[maxn];
    void pushdown(int i)
    {
    if(stu[i].flag)
    {
    stu[i*2].flag=stu[i*2+1].flag=stu[i].flag;
    /// 还需要根据题目的意思 做一些处理
    }
    }
    void updata(int l,int r,int i)//l , r 为需要查找区间的范围 x y 为目的区间
    {
    if(x<=l&&r<=y)//找到对应的区间
    {

    return;
    }
    int mid=(l+r)/2;
    pushdown(i);
    if(x<=mid) updata(l,mid,i*2);
    if(y>mid) updata(mid+1,r,i*2+1);
    }

    poj hotel

    #include<iostream>  
    #define maxn 50010  
    using namespace std;  
    int n,m,a,b;  
    int cmd;  
    struct stu  
    {  
        int r,l;  
        int flag;  
        int tlen,llen,rlen;  
        int up()  
        {  
            tlen=llen=rlen=(flag? 0:r-l+1);  
        }  
    };  
    stu mapp[maxn*4];  
    void build(int l,int r,int count)  
    {  
        mapp[count].l=l;  
        mapp[count].r=r;  
        mapp[count].tlen=mapp[count].llen=mapp[count].rlen=r-1+1;  
        mapp[count].flag=0;  
        if(l==r) return;  
        int mid=(l+r)/2;  
        build(l,mid,count*2);  
        build(mid+1,r,count*2+1);  
    }  
    void push(int count)  //延迟更新
    {  
        if(mapp[count].flag!=-1)  
        {  
            mapp[count*2].flag=mapp[count*2+1].flag=mapp[count].flag;  
            mapp[count].flag=-1;  
            mapp[count*2].up();  
            mapp[count*2+1].up();  
        }  
       
    }  
    int que(int l,int r,int count)  
    {  
        if(mapp[count].l==mapp[count].r&&mapp[count].tlen) return mapp[count].l;  
        push(count);  
        if(mapp[count*2].tlen>=a) return que(l,r,count*2);  
        else if(mapp[count*2].rlen+mapp[count*2+1].llen>=a)  
        {  
            return mapp[count*2].r-mapp[count*2].rlen+1;  
        }  
        else if(mapp[count*2+1].tlen>=a) return que(l,r,count*2+1);  
        else return 0;  
    }  
    void updata(int l,int r,int v,int count)  
      {  
        if(mapp[count].l==l&&mapp[count].r==r)  
        {  
            mapp[count].flag=v;    
    	      mapp[count].up();  
            return;  
        }  
        push(count);  
        int mid=(mapp[count].l+mapp[count].r)/2;  
        if(r<=mid) updata(l,r,v,count*2);  
        else if(l>=mid+1) updata(l,r,v,count*2+1);  
        else  
        {  
           updata(l,mid,v,count*2);  
          updata(mid+1,r,v,count*2+1);  
        }  
        int tmp=max(mapp[count*2].tlen,mapp[count*2+1].tlen);  // 后面为pushup函数
        mapp[count].tlen=max(tmp,mapp[count*2].rlen+mapp[count*2+1].llen);   
    	  mapp[count].llen=mapp[count*2].llen;  
       mapp[count].rlen=mapp[count*2+1].rlen;  
        if(mapp[count*2].tlen==(mapp[count*2].r-mapp[count*2].l+1))  
        {  
            mapp[count].llen+=mapp[count*2+1].llen;  
        }  
        if(mapp[count*2+1].tlen==(mapp[count*2+1].r-mapp[count*2+1].l+1))  
       {  
            mapp[count].rlen+=mapp[count*2].rlen;  
       }  
    }  
    int main()  
    {  
        cin.sync_with_stdio(false);  
        while(cin>>n>>m)  
        {  
            build(1,n,1);      
    		    for(int i=0;i<m;i++)  
            {  
                cin>>cmd;  
                if(cmd==1)  
               {  
                    cin>>a;  
                    int ans=que(1,n,1);  
                    cout<<ans<<endl;  
                    if(ans) updata(ans,ans+a-1,1,1);  
               }     
               else  
                {  
                   cin>>a>>b;  
                    updata(a,a+b-1,0,1);  
               }  
            }  
       }  
        return 0;  
    }  
    
  • 相关阅读:
    深入理解JVM(二)--对象的创建
    深入理解JVM(一) -- 自动内存管理机制
    代理模式(Proxy)
    心知天气数据API 产品的高并发实践
    Jenkins 构建踩坑经历
    log4net SmtpAppender 踩坑总结
    从 ASP.NET Core 2.1 迁移到 2.2 踩坑总结
    在Windows上安装 Consul
    redis-desktop-manager 0.9.3 安装(最后一个免费版本)
    在Windows上安装Redis
  • 原文地址:https://www.cnblogs.com/z1141000271/p/5741657.html
Copyright © 2020-2023  润新知