码迷,mamicode.com
首页 > 其他好文 > 详细

bzoj4690: Never Wait for Weights 并查集

时间:2016-08-27 20:43:14      阅读:130      评论:0      收藏:0      [点我收藏+]

标签:

裸带权并查集

#include<cstdio>
#define N 100005
int m,i,j,s,t,u,d[N],p[N];
char k;
int find(int i){
	if(p[i]^i&&find(p[i]))
		d[i]+=d[p[i]];
	return p[i]=p[p[i]];
}
int main(){
	while(scanf("%d%d",&s,&m)&&s){
		for(;s;--s)
			d[p[s]=s]=0;
		while(m--){
			scanf(" %c%d%d",&k,&s,&t);
			i=find(s),j=find(t);
			if(k==‘!‘){
				scanf("%d",&u);
				p[i]=j;
				d[i]=d[t]+u-d[s];
			}else if(i^j)
				puts("UNKNOWN");
			else
				printf("%d\n",d[s]-d[t]);
		}
	}
}

  

bzoj4690: Never Wait for Weights 并查集

标签:

原文地址:http://www.cnblogs.com/f321dd/p/5813652.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!