bzoj 2157: 旅游

额,lct一下。。。注意一下细节就可以,,(然并卵,还是搞错)

  1 #include<bits/stdc++.h>
  2 #define N 200005
  3 #define LL long long
  4 #define inf 0x3f3f3f3f
  5 #define ls c[x][0]
  6 #define rs c[x][1]
  7 using namespace std;
  8 inline int ra()
  9 {
 10     int x=0,f=1; char ch=getchar();
 11     while (ch<'0' || ch>'9') {if (ch=='-') f=-1; ch=getchar();}
 12     while (ch>='0' && ch<='9') {x=x*10+ch-'0'; ch=getchar();}
 13     return x*f;
 14 }
 15 int c[N][2],fa[N],mx[N],mn[N],sum[N],val[N],q[N];
 16 bool tag[N],rev[N];
 17 int n;
 18 bool isroot(int x){return c[fa[x]][0]!=x && c[fa[x]][1]!=x;}
 19 bool which(int x){return c[fa[x]][1]==x;}
 20 void pushdown(int x)
 21 {
 22     if (rev[x])
 23     {
 24         rev[x]=0; rev[ls]^=1; rev[rs]^=1; swap(ls,rs);
 25     }
 26     if (tag[x])
 27     {
 28         if (ls) sum[ls]=-sum[ls],swap(mx[ls],mn[ls]),mx[ls]=-mx[ls],mn[ls]=-mn[ls],tag[ls]^=1,val[ls]=-val[ls];
 29         if (rs) sum[rs]=-sum[rs],swap(mx[rs],mn[rs]),mx[rs]=-mx[rs],mn[rs]=-mn[rs],tag[rs]^=1,val[rs]=-val[rs];
 30         tag[x]=0;
 31     }
 32 }
 33 void update(int x)
 34 {
 35     if (x>=n)   //应该把点和边分开判断233,因为点的val会影响答案(应该是这样的) 
 36     {
 37         mx[x]=max(val[x],max(mx[ls],mx[rs]));
 38         mn[x]=min(val[x],min(mn[ls],mn[rs]));
 39     }
 40     else
 41     {
 42         mx[x]=max(mx[ls],mx[rs]);
 43         mn[x]=min(mn[ls],mn[rs]);
 44     }
 45     sum[x]=sum[ls]+sum[rs]+val[x];
 46 }
 47 void rotate(int &x)
 48 {
 49     int y=fa[x],z=fa[y],nx=which(x),ny=which(y);
 50     if (!isroot(y)) c[z][ny]=x; fa[x]=z;
 51     c[y][nx]=c[x][!nx]; fa[c[x][!nx]]=y;
 52     c[x][!nx]=y; fa[y]=x; update(y); update(x);
 53 }
 54 void splay(int &x)
 55 {
 56     int top=0; q[++top]=x;
 57     for (int i=x; !isroot(i); i=fa[i]) q[++top]=fa[i];
 58     while (top) pushdown(q[top--]);
 59     while (!isroot(x))
 60     {
 61         int y=fa[x],z=fa[y];
 62         if (!isroot(y))
 63         {
 64             if (which(x)==which(y)) rotate(y);
 65             else rotate(x);
 66         }
 67         rotate(x);
 68     }
 69 }
 70 void access(int x)
 71 {
 72     for (int t=0; x; t=x,x=fa[x])
 73         splay(x),c[x][1]=t,update(x);
 74 }
 75 void makeroot(int x)
 76 {
 77     access(x); splay(x); rev[x]^=1;
 78 }
 79 void link(int x, int y)
 80 {
 81     makeroot(x); fa[x]=y;
 82 }
 83 void change(int x, int w)
 84 {
 85     makeroot(x); access(x); splay(x); 
 86     mx[x]=w; mn[x]=w; sum[x]=w; val[x]=w;
 87 }
 88 void xfs(int x, int y)
 89 {
 90     makeroot(x); access(y); splay(y);
 91     swap(mn[y],mx[y]); mn[y]=-mn[y]; mx[y]=-mx[y];
 92     sum[y]=-sum[y]; val[y]=-val[y]; tag[y]^=1;
 93 }
 94 int askmax(int x, int y)
 95 {
 96     makeroot(x); access(y); splay(y);
 97     return mx[y];
 98 }
 99 int askmin(int x, int y)
100 {
101     makeroot(x); access(y); splay(y);
102     return mn[y];
103 }
104 int asksum(int x, int y)
105 {
106     makeroot(x); access(y); splay(y);
107     return sum[y];
108 }
109 int main()
110 {
111     n=ra();
112     mn[0]=inf; mx[0]=-inf;
113     for (int i=1; i<n; i++)
114     {
115         int x=ra()+1,y=ra()+1,w=ra();
116         mx[n+i]=w; mn[n+i]=w; sum[n+i]=w; val[n+i]=w;
117         link(x,n+i); link(y,n+i);
118     }
119     int Q=ra();
120     while (Q--)
121     {
122         char s[5];
123         scanf("%s",s+1); int x=ra()+1,y=ra()+1; 
124         if (s[1]=='C') x--,y--,change(n+x,y);
125         if (s[1]=='N') xfs(x,y);
126         if (s[1]=='M' && s[2]=='A') printf("%d\n",askmax(x,y));
127         if (s[1]=='M' && s[2]=='I') printf("%d\n",askmin(x,y));
128         if (s[1]=='S') printf("%d\n",asksum(x,y));
129     }
130     return 0;
131 }

 

posted @ 2017-03-01 07:59  ws_ccd  阅读(127)  评论(0编辑  收藏  举报