博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVALive - 3027:Corporative Network
阅读量:5122 次
发布时间:2019-06-13

本文共 963 字,大约阅读时间需要 3 分钟。

加权并查集

#include
#include
#include
#include
#define MAXN 20000+10#define pii pair
using namespace std;int fa[MAXN];int d[MAXN];int n;int Abs(int x){ return (x>0?x:-x);}pii find(int x){ if(fa[x]!=x){ pii t=find(fa[x]); fa[x]=t.first; d[x]+=t.second; } return make_pair(fa[x],d[x]);}void solve(){ scanf("%d",&n); for(int i=1;i<=n;i++){ fa[i]=i,d[i]=0; } char ch[9]={
0}; while(scanf("%s",ch)&&ch[0]!='O'){ if(ch[0]=='E'){ int x; scanf("%d",&x); printf("%d\n",find(x).second); } else{ int x,y; scanf("%d%d",&x,&y); fa[x]=y; d[x]=Abs(x-y)%1000; } }}int main(){ int T; scanf("%d",&T); while(T--){ solve(); } return 0;}

 

转载于:https://www.cnblogs.com/w-h-h/p/7894795.html

你可能感兴趣的文章
SpringBoot项目打包
查看>>
Linux操作系统 和 Windows操作系统 的区别
查看>>
《QQ欢乐斗地主》山寨版
查看>>
文件流的使用以及序列化和反序列化的方法使用
查看>>
Android-多线程AsyncTask
查看>>
第一个Spring冲刺周期团队进展报告
查看>>
红黑树 c++ 实现
查看>>
Android 获取网络链接类型
查看>>
linux中启动与终止lnmp的脚本
查看>>
gdb中信号的处理[转]
查看>>
LeetCode【709. 转换成小写字母】
查看>>
如何在Access2007中使用日期类型查询数据
查看>>
CF992E Nastya and King-Shamans(线段树二分+思维)
查看>>
第一个Java Web程序
查看>>
树状数组_一维
查看>>
如果没有按照正常的先装iis后装.net的顺序,可以使用此命令重新注册一下:
查看>>
linux install ftp server
查看>>
嵌入式软件设计第8次实验报告
查看>>
算法和数据结构(三)
查看>>
Ubuntu下的eclipse安装subclipse遇到没有javahl的问题...(2天解决了)
查看>>