本文共 1222 字,大约阅读时间需要 4 分钟。
每个线段树节点需要保存四个值,ls,rs,min,tag 由于空间不够 所以把他们压缩成一个unsinged long long t[x] = (ls * N + rs) * T + val + tag t[x] % T 即可得到val + tag, ls = t[x] / T / N, rs = t[x] / T % N 进行标记永久化过后可以用左右儿子的值解出自己的val,再解出tag 然后就卡着内存过去了 黑科技简直可怕 code(爆空间的)#include#include #include #include #include #include using namespace std;vector vec[200010];struct trnode{ int lc,rc,c,u;}tr[3800010];int tot=0,root[200010];void update(int &x,int l,int r,int fl,int fr,int c){ tr[++tot]=tr[x];x=tot; if(l==fl&&r==fr) { tr[x].c+=c;tr[x].u+=c;return;} int mid=(l+r)/2; if(fr<=mid) update(tr[x].lc,l,mid,fl,fr,c); else if(fl>mid) update(tr[x].rc,mid+1,r,fl,fr,c); else update(tr[x].lc,l,mid,fl,mid,c),update(tr[x].rc,mid+1,r,mid+1,fr,c); tr[x].c=min(tr[tr[x].lc].c,tr[tr[x].rc].c)+tr[x].u;}int findans(int x,int l,int r,int fl,int fr){ if(!x) return 0; if(l==fl&&r==fr) return tr[x].c; int mid=(l+r)/2; if(fr<=mid) return findans(tr[x].lc,l,mid,fl,fr)+tr[x].u; if(fl>mid) return findans(tr[x].rc,mid+1,r,fl,fr)+tr[x].u; return min(findans(tr[x].lc,l,mid,fl,mid),findans(tr[x].rc,mid+1,r,mid+1,fr))+tr[x].u;}int n,m,cnt=0,b[200010];struct node{ int a,num;}a[200010];bool cmp(node a,node b) { return a.a
转载地址:http://kmza.baihongyu.com/