zoukankan      html  css  js  c++  java
  • 整理下线段树吧 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;  
    }  
    
  • 相关阅读:
    你的课程
    asp.net的ajax以及json
    asp.net自带的异步刷新控件使用
    基于.net mvc的校友录(源程序)
    基于.net mvc的校友录(七、文件上传以及多对多关系表的LINQ查询实现)
    基于.net mvc的校友录(六、codefirst的使用以及班级模块的关键部分实现)
    逻辑回归实例
    层次聚类
    k均值聚类
    数据处理与转换
  • 原文地址:https://www.cnblogs.com/z1141000271/p/5741657.html
Copyright © 2011-2022 走看看