2012-2013 ACM-ICPC, Asia Tokyo Regional Contest F.Never Wait for Weights(带权并查集模板)

来源:互联网 发布:mac磁盘分区失败 编辑:程序博客网 时间:2024/06/10 20:09

题目大意:

存在着n个物品,然后有m次操作

!  x y l

表示y比x重l

x y

表示询问y比x重多少

解题思路:

这是一道带权并查集的问题,之前没有触及到,所以这次遇到就补充一下

#include<iostream>  #include<cstdio>#include<stdio.h>#include<cstring>#include<cstdio>#include<climits>   #include<cmath> #include<vector>  #include <bitset>  #include<algorithm>    #include <queue>  #include<map> #define inf 9999999;using namespace std;typedef long long LL;int n,T;int fa[100005],rank[100005];int getf(int x){if(x==fa[x])return x;int k=getf(fa[x]);rank[x]+=rank[fa[x]];return fa[x]=k;}void init(){for(int i=1;i<=n;i++){fa[i]=i;rank[i]=0;}}int main(){char s;int t1,t2;int x,y,l,i;for(;;){scanf("%d%d",&n,&T);init();if(n==0&&T==0)break;while(T--){scanf("%s",&s);//cin>>s;if(s=='!'){scanf("%d%d%d",&x,&y,&l);t1=getf(x);t2=getf(y);if(t1!=t2){fa[t2]=t1;rank[t2]=rank[x]+l-rank[y];}}else{scanf("%d%d",&x,&y);t1=getf(x);t2=getf(y);if(t1!=t2)printf("UNKNOWN\n");elseprintf("%d\n",rank[y]-rank[x]);//cout<<rank[y]-rank[x]<<endl;;}}}}


阅读全文
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 微医爽约过一次怎么办 炸完的薯条软了怎么办 学信网号码换了怎么办 学信网注册换手机了怎么办 学信网手机号码已被注册怎么办 学信网手机号码被注册了怎么办 去英国留学不会做饭怎么办 小米陶瓷刀钝了怎么办 橱柜的缝擦不到怎么办 悠悠球上油早了怎么办 买了没有esp的车怎么办 饥荒海难狗来了怎么办 饥荒海难拖网掉水里了怎么办 饥荒遇到了猪人怎么办 饥荒龙蝇赖在家不走怎么办 饥荒海难崩档了怎么办 gta5全是rpf文件怎么办 饥荒没有海象人营地怎么办 饥荒海滩猎犬来了怎么办 宝宝换牙门牙上长颗尖牙怎么办 肉卡在牙缝里怎么办 电脑做系统卡死怎么办 苹果6升级太卡怎么办 电脑玩不了联机饥荒怎么办 饥荒渡渡鸟死了一只怎么办 饥荒电脑联机植物生病怎么办 开车蹭到别人车怎么办 立定跳不会收腹怎么办 1岁宝宝有蛔虫怎么办 手机屏幕总是有网页跳出来怎么办 cs游戏屏幕变成正方形怎么办 大王卡被收回了怎么办 模拟人生4小人生病了怎么办 创造与魔法死后怎么办? 脚不小心扭伤了该怎么办 小鸡脚扭伤了该怎么办 跳高比赛最终成绩相等怎么办 热车1200怠速降不下来怎么办 大腿根骨髓水肿越来越疼怎么办 倒库方向打晚了怎么办 签吻芳颜祛斑液脸脱皮怎么办