题目描述

约翰和贝茜在玩一个方块游戏。编号为 1\ldots n 1…n 的 n n ( 1 \leq n \leq 30000 1≤n≤30000 )个方块正放在地上,每个构成一个立方柱。

游戏开始后,约翰会给贝茜发出 P (1≤P≤100000 )个指令。指令有两种:

移动(M):将包含X的立方柱移动到包含Y的立方柱上。

统计(C):统计含X的立方柱中,在X下方的方块数目。

写个程序帮贝茜完成游戏。

输入输出格式

输入格式:

第1行输入 P ,之后 P 行每行输入一条指令,形式为“M X Y”或者“C X”。

输入保证不会有将立方柱放在自己头上的指令。

输出格式:

输出共 P 行,对于每个统计指令,输出其结果。

输入输出样例

输入样例#1:

6

M 1 6

C 1

M 2 4

M 2 6

C 3

C 4

输出样例#1:

1

0

2


这个作为带权并查集的模板,来复习一下。

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 1200000;
int n, fa[N], dis[N], siz[N], x, y;
char opt;
int find(int x) {
if (fa[x] == x)
return x;
int which = find(fa[x]);
dis[x] += dis[fa[x]];
fa[x] = which;
return which;
}
signed main() {
cin >> n;
for (int i = 1; i <= 30000; i++) {
fa[i]=i;
siz[i] = 1;
}
while (n--) {
cin >> opt;
if (opt == 'M') {
cin >> x >> y;
int xx=find(x),yy=find(y);
fa[xx]=yy;
dis[xx] += siz[yy];
siz[yy] += siz[xx];
} else if (opt == 'C') {
cin >> x;
find(x);
cout << dis[x] << '\n';
}
}
return 0;
}

最新文章

  1. python学习 异常
  2. 在SQL Server 2005中连接Oracle,完成查询、插入操作
  3. MFC对话框中显示BMP,JPG图片
  4. WITH AS短语,也叫做子查询部分(subquery factoring)
  5. 使用hibernate tools插件生成POJO
  6. Android中的六大布局
  7. XLSTransformer生成excel文件简单演示样例
  8. 积累的VC编程小技巧之打印相关
  9. NodeJs之crypto
  10. 闭锁——CountDownLatch
  11. 【java】method.invoke(方法底层所属对象/null,new Object[]{实际参数})
  12. Git 教程(二):提交和回退
  13. Django 模板 继承和包含
  14. ubuntu 使用旧式Gnome风格的菜单
  15. MySQL -- 外键创建失败
  16. C# Int转Enum
  17. Kubernetes init container
  18. Count the string HDU - 3336
  19. ambari 大数据安装利器
  20. 软件架构的描述-Architecture Models

热门文章

  1. mysql 基本操作 一
  2. HTML5微信jssdk录音播放语音的方法
  3. Linux内核宏DEVICE_ATTR使用
  4. 内网服务器离线编译安装mysql5.7并调优
  5. 串口调试工具与com口编程
  6. sqlException 使用relace 替换单引号
  7. 存储过程中的BeginEnd
  8. windows下隐藏磁盘分区(转)
  9. java之maven之初识maven
  10. 经实验验证,修正对using namespace std的认识