1. 程式人生 > >uoj279溫暖會指引我們前行

uoj279溫暖會指引我們前行

bsp swap esp struct view cst include printf const

暖氣來啦~

動態樹維護最大生成樹裸題

技術分享圖片
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
inline int read()
{
    int x=0,f=1;char ch=getchar();
    while(ch<0||ch>9){if(ch==-)f=-1;ch=getchar();}
    
while(ch>=0&&ch<=9){x=x*10+ch-0;ch=getchar();} return x*f; } const int maxn=400010; int es[maxn][2]; int n,m; int rt,Size; struct LCT { int son[maxn][2],f[maxn],val[maxn],size[maxn],cnt[maxn],rev[maxn],st[maxn]; int t[maxn],len[maxn],mn[maxn],sum[maxn]; inline void update(int
x) { int &o=x,lch=son[x][0],rch=son[x][1]; mn[o]=x;sum[o]=len[o]; if(son[x][0]) { if(t[mn[lch]]<t[mn[x]]) mn[o]=mn[lch]; sum[o]+=sum[lch]; } if(son[x][1]) { if(t[mn[rch]]<t[mn[x]]) mn[o]=mn[rch]; sum[o]
+=sum[rch]; } } inline int isroot(int x){return son[f[x]][0]!=x && son[f[x]][1]!=x;} inline void rotate(int x) { int y=f[x],z=f[y],l,r; if(son[y][0]==x)l=0; else l=1;r=l^1; if(!isroot(y)) { if(son[z][0]==y)son[z][0]=x; else son[z][1]=x; } f[x]=z;f[y]=x;f[son[x][r]]=y; son[y][l]=son[x][r];son[x][r]=y; update(y); } inline void pushdown(int id) { int lch=son[id][0],rch=son[id][1]; if(rev[id]) { rev[id]^=1;rev[lch]^=1;rev[rch]^=1; swap(son[id][0],son[id][1]); } } inline void Splay(int x) { int top=0;st[++top]=x; for(int i=x;!isroot(i);i=f[i])st[++top]=f[i]; for(int i=top;i;i--)pushdown(st[i]); while(!isroot(x)) { int y=f[x],z=f[y]; if(!isroot(y)) { if(son[y][0]==x^son[z][0]==y)rotate(x); else rotate(y); } rotate(x); } update(x); } inline void access(int x) { int t=0; while(x) { Splay(x); son[x][1]=t; t=x; x=f[x]; update(x); } } inline void makert(int x){access(x);Splay(x);rev[x]^=1;} inline void link(int x,int y){makert(x);f[x]=y;} inline void cut(int x,int y){makert(x);access(y);Splay(y);son[y][0]=f[x]=0;update(y);} inline int findf(int x) { access(x);Splay(x); int y=x; while(son[y][0])y=son[y][0]; return y; } }Tree; char opt[10]; int main() { scanf("%d%d",&n,&m); int k,x,y,z; for(int i=1;i<=n;i++)Tree.t[i]=2147483233; while(m--) { scanf("%s",opt); if(opt[0]==f) { scanf("%d%d%d",&z,&x,&y);z++,x++,y++; z+=n;es[z][0]=x,es[z][1]=y; scanf("%d%d",&Tree.t[z],&Tree.len[z]); if(Tree.findf(x)!=Tree.findf(y)){Tree.link(z,x),Tree.link(z,y);} else { Tree.makert(x);Tree.access(y);Tree.Splay(y); if(Tree.t[Tree.mn[y]]<Tree.t[z]) { k=Tree.mn[y];Tree.cut(k,es[k][0]);Tree.cut(k,es[k][1]); Tree.link(z,x),Tree.link(z,y); } } } else if(opt[0]==m) { scanf("%d%d",&x,&y);x++,y++; if(Tree.findf(x)!=Tree.findf(y))puts("-1"); else { Tree.makert(x);Tree.access(y);Tree.Splay(y); printf("%d\n",Tree.sum[y]); } } else { scanf("%d%d",&x,&y);x++; x+=n;Tree.Splay(x);Tree.len[x]=y;Tree.update(x); } } }
View Code

uoj279溫暖會指引我們前行