整理下线段树吧 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;  
}  
posted @ 2016-08-05 15:50  猪突猛进!!!  阅读(130)  评论(0编辑  收藏  举报