hdu3635 Dragon Balls

His country has N cities and there are exactly N dragon balls in the world. At first, for the ith dragon ball, the sacred dragon will puts it in the ith city. Through long years, some cities' dragon ball(s) would be transported to other cities. To save physical
strength WuKong plans to take Flying Nimbus Cloud, a magical flying cloud to gather dragon balls.
Every time WuKong will collect the information of one dragon ball, he will ask you the information of that ball. You must tell him which city the ball is located and how many dragon balls are there in that city, you also need to tell him how many times the
ball has been transported so far.
For each case, the first line contains two integers: N and Q (2 < N <= 10000 , 2 < Q <= 10000).
Each of the following Q lines contains either a fact or a question as the follow format:
T A B : All the dragon balls which are in the same city with A have been transported to the city the Bth ball in. You can assume that the two cities are different.
Q A : WuKong want to know X (the id of the city Ath ball is in), Y (the count of balls in Xth city) and Z (the tranporting times of the Ath ball). (1 <= A, B <= N)
3 3
T 1 2
T 3 2
Q 2
3 4
T 1 2
Q 1
T 1 3
Q 1
2 3 0
Case 2:
2 2 1
3 3 2
这题考查了并查集的路径压缩,这道题让我对路径压缩有了进一步了解,题意是初始时,有n个龙珠,编号从1到n,分别对应的放在编号从1到n的城市中。2种操作:
Q A,表示查询A。要求得到的信息分别是:A现在所在的城市,A所在城市的龙珠数目,A转移到该城市移动的次数(如果没有移动就输出0)
#include<string.h>
int pre[10006],zhuanyi[10006],num[10006];
char s[10];
int find(int x)
{
int temp;
if(x==pre[x])return x;
temp=pre[x];
pre[x]=find(pre[x]);
zhuanyi[x]+=zhuanyi[temp];
return pre[x];
}
int main()
{
	int T,n,m,i,j,a,b,c,t1,t2,num1=0;
	scanf("%d",&T);
	while(T--)
	{
		num1++;
		printf("Case %d:\n",num1);
		scanf("%d%d",&n,&m);
		for(i=1;i<=n;i++){
			pre[i]=i;zhuanyi[i]=0;num[i]=1;  //pre[]表示球的父亲,zhuangyi[]表示球转移的次数,num[i]表示球i所在城市的球的个数 
		}
		for(i=1;i<=m;i++){
			scanf("%s",s);
			if(s[0]=='T'){
				scanf("%d%d",&a,&b);
				t1=find(a);t2=find(b);
				if(t1==t2)continue;
				pre[t1]=t2;
				num[t2]+=num[t1];
				zhuanyi[t1]=1;
			}
			else if(s[0]=='Q'){
				scanf("%d",&a);
				t1=find(a);
				printf("%d %d %d\n",t1,num[t1],zhuanyi[a]);
			}
		}
	}
	return 0;
}
hdu3635 Dragon Balls的更多相关文章
- hdu3635 Dragon Balls(带权并查集)
		/* 题意:有N个城市, 每一个城市都有一个龙珠(编号与城市的编号相同),有两个操作 T A ,B 将标号为A龙珠所在城市的所有的龙珠移动到B龙珠所在城市中! 思路:并查集 (压缩路径的时候将龙珠移动 ... 
- Dragon Balls[HDU3635]
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ... 
- hdu 3635 Dragon Balls(并查集)
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ... 
- hdu  3635 Dragon Balls (带权并查集)
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ... 
- hdu 3635 Dragon Balls
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ... 
- hdoj 3635 Dragon Balls【并查集求节点转移次数+节点数+某点根节点】
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ... 
- hdu 3635 Dragon Balls(并查集应用)
		Problem Description Five hundred years later, the number of dragon balls will increase unexpectedly, ... 
- Dragon Balls
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- HDU 3635:Dragon Balls(并查集)
		Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ... 
随机推荐
- [从源码学设计]蚂蚁金服SOFARegistry之续约和驱逐
			[从源码学设计]蚂蚁金服SOFARegistry之续约和驱逐 目录 [从源码学设计]蚂蚁金服SOFARegistry之续约和驱逐 0x00 摘要 0x01 业务范畴 1.1 失效剔除 1.2 服务续约 ... 
- 从一次生产消费者的bug看看线程池如何增加线程
			0 背景 某个闲来无事的下午,看到旧有的项目中,有个任务调度的地方都是同步的操作,就是流程A的完成依赖流程B,流程B的完成依赖流程C,按此类推. 作为一名垃圾代码生产者,QA的噩梦.故障报告枪手的我来 ... 
- 【Linux】nohup和&的区别
			同样都是后台执行进程,但是nohup和&有什么区别呢? & 是指后台运行: nohup 的功能和& 之间的功能并不相同. 其中,nohup 可以使得命令永远运行下去和用户终端没 ... 
- CTFshow萌新赛-密码学签到
			查看密码信息 猜测为base家族 存在"^"符号,所以应该是在base64以上 使用base85解密 成功拿到flag 
- python之格式化字符串速记整理
			一.格式化字符串的方式: 1.字符串表达式: 语法格式:'%s' % var 或 '%s %d' % (var1, var2) 说明:%s.%d等为格式类型说明符 例子: >>> ... 
- 【对线面试官】Java多线程基础
			// 请求直接交给线程池来处理 public void push(PushParam pushParam) { try { pushServiceThreadExecutor.submit(() -& ... 
- Electron入门Demo之桌面应用计算器笔记(二)
			码文不易啊,转载请带上本文链接呀,感谢感谢 https://www.cnblogs.com/echoyya/p/14307996.html 在之前总结了一篇自学笔记,通过之前学习到的方法和知识,完成了 ... 
- Kubernetes 开船记-脚踏两只船:用 master 服务器镜像克隆出新集群
			自从2020年2月23日 园子全站登船 之后,我们一边感叹"不上船不知道,一上船吓一跳" -- kubernetes 比 docker swarm 强大太多,一边有一个杞人忧天的担 ... 
- Nginx报504 gateway timeout错误的解决方法(小丑搞笑版。。。)
			一.今天登录我的网站,突然发现报了下面的一个错误: 我的第一反应是:超时了应该是Nginx代理没有设置超时时间,默认的超时时间估计太小了,然后就按照正常的方式用Xshell连接服务器,应该是网络或者是 ... 
- MySQL ---- 锁知识
			锁 我们知道mysql中支持很多个存储引擎,在不同的存储引擎下所能支持的锁是不同的,我们通过MyISAM和InnoDB来进行一下对比. 表级锁定(table-level)  表级别的锁定是MySQL ... 
