Codeforces Round #576 (Div. 2) D. Welfare State + hdu5306 Gorgeous Sequence (吉司机线段树)

存个板子

n(logn)2\mathbb 更新操作区间取最值 ,n(logn)^2

Codeforces Round #576 (Div. 2) D. Welfare State

#include<bits/stdc++.h>
using namespace std;
#define ls rt<<1
#define rs (rt<<1)+1
#define PI acos(-1)
#define eps 1e-8
#define ll long long
#define fuck(x) cout<<#x<<"     "<<x<<endl;
typedef pair<int,int> pii;
const int inf=2e9;
const int maxn=2e5+10;
int d[4][2]={1,0,-1,0,0,1,0,-1};
//int lowbit(int x){return x&-x;}
//void add(int x,int v){while(x<=n)bit[x]+=v,x+=lowbit(x);}
//int sum(int x){int ans=0;while(x>=1) ans+=bit[x],x-=lowbit(x);return ans;}
inline ll read() {
  ll s = 0,w = 1;
  char ch = getchar();
  while(!isdigit(ch)) {
      if(ch == '-') w = -1;
      ch = getchar();
  }
  while(isdigit(ch))
      s = s * 10 + ch - '0',ch = getchar();
  return s * w;
}
inline void write(ll x) {
  if(x < 0)
      putchar('-'), x = -x;
  if(x > 9)
      write(x / 10);
  putchar(x % 10 + '0');
}

int minn[maxn<<2],sminn[maxn<<2],lazy[maxn<<2],a[maxn];


void pushup(int rt){
  if(minn[ls]!=minn[rs]){
      minn[rt]=min(minn[ls],minn[rs]);
      sminn[rt]=min(max(minn[ls],minn[rs]),min(sminn[ls],sminn[rs]));
  }
  else
  {
      minn[rt]=minn[ls];
      sminn[rt]=min(sminn[ls],sminn[rs]);
  }
}
void pushdown(int rt){
  if(lazy[rt]!=-1){
      if(minn[ls]<lazy[rt]&&sminn[ls]>lazy[rt]){
          minn[ls]=lazy[rt];
          lazy[ls]=lazy[rt];
      }
      if(minn[rs]<lazy[rt]&&sminn[rs]>lazy[rt]){
          minn[rs]=lazy[rt];
          lazy[rs]=lazy[rt];
      }
      lazy[rt]=-1;
  }
}
void build(int rt,int L,int R){
  lazy[rt]=-1;
  if(L==R){
      minn[rt]=a[L];
      sminn[rt]=inf;
      return ;
  }
  int mid=(L+R)>>1;
  build(ls,L,mid);
  build(rs,mid+1,R);
  pushup(rt);
}

void update1(int rt,int L,int R,int x){
  if(minn[rt]>=x) return;
  if(sminn[rt]>x){
      minn[rt]=x;
      lazy[rt]=x;
      return ;
  }
  pushdown(rt);
  int mid=(L+R)>>1;
  update1(ls,L,mid,x);
  update1(rs,mid+1,R,x);
  pushup(rt);
}

void update2(int rt,int L,int R,int x,int y){
  if(L==R){
      minn[rt]=y;
      return ;
  }
  pushdown(rt);
  int mid=(L+R)>>1;
  if(x<=mid)
      update2(ls,L,mid,x,y);
  else
      update2(rs,mid+1,R,x,y);
  pushup(rt);
}
int query(int rt,int L,int R,int x){
  if(L==R)
      return minn[rt];
  int mid=(L+R)>>1;
  pushdown(rt);
  if(x<=mid)
      return query(ls,L,mid,x);
  else
      return query(rs,mid+1,R,x);
}
int main(){
  int n,q;
  n=read();
  for(int i=1;i<=n;i++)
      a[i]=read();
  build(1,1,n);
  q=read();
  while(q--){
      int opt,x,y;
      opt=read();
      if(opt==1){
          x=read();y=read();
          update2(1,1,n,x,y);
      }
      else{
          x=read();
          update1(1,1,n,x);
      }
  }
  for(int i=1;i<=n;i++){
      write(query(1,1,n,i));
      printf(" ");
  }
  puts("");
  return 0;
}





hdu5306 Gorgeous Sequenc

#include<bits/stdc++.h>
using namespace std;
#define ls rt<<1
#define rs (rt<<1)+1
#define PI acos(-1)
#define eps 1e-8
#define ll long long
#define fuck(x) cout<<#x<<"     "<<x<<endl;
typedef pair<int,int> pii;
const int inf=2e9;
const int maxn=1e6+10;
int d[4][2]={1,0,-1,0,0,1,0,-1};
//int lowbit(int x){return x&-x;}
//void add(int x,int v){while(x<=n)bit[x]+=v,x+=lowbit(x);}
//int sum(int x){int ans=0;while(x>=1) ans+=bit[x],x-=lowbit(x);return ans;}
inline ll read() {
    ll s = 0,w = 1;
    char ch = getchar();
    while(!isdigit(ch)) {
        if(ch == '-') w = -1;
        ch = getchar();
    }
    while(isdigit(ch))
        s = s * 10 + ch - '0',ch = getchar();
    return s * w;
}
inline void write(ll x) {
    if(x < 0)
        putchar('-'), x = -x;
    if(x > 9)
        write(x / 10);
    putchar(x % 10 + '0');
}

int a[maxn],lazy[maxn<<2],maxx[maxn<<2],smax[maxn<<2],mnum[maxn<<2];
ll sum[maxn<<2];

void pushup(int rt){
    if(maxx[ls]!=maxx[rs]){
        maxx[rt]=max(maxx[ls],maxx[rs]);
        mnum[rt]=(maxx[rt]==maxx[ls])?mnum[ls]:mnum[rs];
        smax[rt]=max(max(smax[ls],smax[rs]),min(maxx[ls],maxx[rs]));
    }
    else
    {
        maxx[rt]=maxx[ls];
        mnum[rt]=mnum[ls]+mnum[rs];
        smax[rt]=max(smax[ls],smax[rs]);
    }
    sum[rt]=sum[ls]+sum[rs];
}
void pushdown(int rt){
    if(lazy[rt]!=-1){
        if(maxx[ls]>lazy[rt]&&lazy[rt]>smax[ls]){
            sum[ls]-=1LL*mnum[ls]*(maxx[ls]-lazy[rt]);
            maxx[ls] = lazy[rt];
            lazy[ls] = lazy[rt];
        }
        if(maxx[rs]>lazy[rt]&&lazy[rt]>smax[rs]){
            sum[rs]-=1LL*mnum[rs]*(maxx[rs]-lazy[rt]);
            maxx[rs]=lazy[rt];
            lazy[rs]=lazy[rt];
        }
        lazy[rt]=-1;
    }
}


void build(int rt,int L,int R){
    lazy[rt]=-1;
    if(L==R){
        sum[rt]=maxx[rt]=a[L];
        smax[rt]=-1;
        mnum[rt]=1;
        return ;
    }
    int mid=(L+R)>>1;
    build(ls,L,mid);
    build(rs,mid+1,R);
    pushup(rt);
}
void update(int rt,int L,int R,int l,int r,int v){
    if(l<=L&&r>=R){
        if(v>=maxx[rt]) return ;
        if(v>smax[rt]){
            sum[rt]-=1LL*mnum[rt]*(maxx[rt]-v);
            maxx[rt]=v;
            lazy[rt]=v;
            return ;
        }
    }
    pushdown(rt);
    int mid=(L+R)>>1;
    if(r<=mid)
        update(ls,L,mid,l,r,v);
    else
        if(l>mid)
            update(rs,mid+1,R,l,r,v);
        else{
            update(ls,L,mid,l,r,v);
            update(rs,mid+1,R,l,r,v);
        }
    pushup(rt);
}
int querym(int rt,int L,int R,int l,int r){
    if(l<=L&&r>=R)
        return maxx[rt];
    pushdown(rt);
    int mid=(L+R)>>1;
    if(r<=mid)
        return querym(ls,L,mid,l,r);
    else
        if(l>mid)
            return querym(rs,mid+1,R,l,r);
        else
            return max(querym(ls,L,mid,l,r),querym(rs,mid+1,R,l,r));
}
ll querys(int rt,int L,int R,int l,int r){
    if(l<=L&&r>=R)
        return sum[rt];
    pushdown(rt);
    int mid=(L+R)>>1;
    if(r<=mid)
        return querys(ls,L,mid,l,r);
    else
        if(l>mid)
            return querys(rs,mid+1,R,l,r);
        else
            return querys(ls,L,mid,l,r)+querys(rs,mid+1,R,l,r);
}
int main(){
    int t,n,m;
    t=read();
    while(t--){
        n=read();m=read();
        for(int i=1;i<=n;i++)
            a[i]=read();
        build(1,1,n);
        //fuck(sum[7]);
       // fuck(maxx[7]);
        while(m--){
            int op,x,y,t;
            op=read();
            if(op==0){
                x=read();y=read();t=read();
                update(1,1,n,x,y,t);
            }
            else
                if(op==1){
                    x=read();y=read();
                    write(querym(1,1,n,x,y));
                    puts("");
                }
                else{
                    x=read();y=read();
                    write(querys(1,1,n,x,y));
                    puts("");
                }
//            int index;
//            index=read();
//            fuck(sum[index]);
//            fuck(maxx[index]);
        }
    }
    return 0;
}

posted @ 2019-09-10 22:36  eason99  阅读(107)  评论(0编辑  收藏  举报