2018杭电多校 第五场 1007补题 线段树

少壮不努力,自挂线段树。

被打的自闭成环了,唉。

 

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6356

AC(跑的死慢的)代码

#include
#define INF 0x3f3f3f3f
#define lson l, mid, pos<<1
#define rson mid+1,r,pos<<1|1
using namespace std;
const int maxn = 1e5+10;
long long f[3], lim;
long long pos[maxn<<2], mi[maxn<<2], mx[maxn<<2], lazy[maxn<<2];
long long sum;
int n,m;
long long li,ri,vi;
unsigned int x, y, z, w;
unsigned int rng(){
    x=x^(x<<11);    x=x^(x>>4); x=x^(x<<5); x=x^(x>>14);
    w=x^(y^z);  x=y;    y=z;    z=w;
    return z;
}

void pushdown(int pos){
    if (lazy[pos]==0)
        return ;
    lazy[pos<<1]=lazy[pos<<1|1]=mx[pos<<1]=mx[pos<<1|1]=mi[pos<<1]=mi[pos<<1|1]=lazy[pos];
    lazy[pos]=0;
    return ;
}
void init(int l, int r, int pos){
    mx[pos]=mi[pos]=lazy[pos]=0;
    if (l==r){
        return ;
    }
    int mid = (l+r)>>1;
    init(lson); init(rson);
    return ;
}

void change(int l, int r, int pos, int L, int R){
    if (mi[pos]>=vi){
        return ;
    }
    if (l>R || r=L&&r<=R){
        if (mx[pos]>1;
        change(lson,L,R);   change(rson,L,R);
        mx[pos]=max(mx[pos<<1],mx[pos<<1|1]);   mi[pos]=min(mi[pos<<1],mi[pos<<1|1]);
        return ;
    }
    pushdown(pos);
    int mid = (l+r)>>1;
    change(lson,L,R);   change(rson,L,R);
    mx[pos]=max(mx[pos<<1],mx[pos<<1|1]);   mi[pos]=min(mi[pos<<1],mi[pos<<1|1]);
    return ;
}


void update(int l, int r, int pos){
    if (mx[pos]==mi[pos]){
        for (int i=l;i<=r;++i){
            sum=sum^(i*mx[pos]);
        }
        return ;
    }
    pushdown(pos);
    int mid = (l+r)>>1;
    update(lson);   update(rson);
    return ;}

void read(){
    scanf("%d%d%u%u%u",&n,&m,&x,&y,&z);
    init(1,n,1);
    for (int i=0;i

 

你可能感兴趣的:(数据结构)