#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 30010
using namespace std;
int m,fa[maxn],top[maxn],num[maxn];
char s;
int find(int x)
{
if(x==fa[x])return x;
int f=fa[x];
fa[x]=find(fa[x]);
num[x]=num[x]+num[f];
return fa[x];
}
void merge(int a,int b)
{
int r1=find(a);
int r2=find(b);
fa[r1]=r2;
find(top[r2]);
num[r1]=num[top[r2]]+;
top[r2]=top[r1];
}
int main()
{
scanf("%d",&m);
int x,y;
for(int i=;i<=;i++)
fa[i]=top[i]=i;
for(int i=;i<=m;i++)
{
cin>>s;
if(s=='M')
{
scanf("%d%d",&x,&y);
if(find(x)==find(y))continue;
merge(x,y);
}
if(s=='C')
{
scanf("%d",&x);
int tmp=find(x);
printf("%d\n",num[x]);
}
}
return ;
}
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 30010
using namespace std;
int m,fa[maxn],top[maxn],num[maxn];
char s;
int find(int x)
{
if(x==fa[x])return x;
int f=fa[x];
fa[x]=find(fa[x]);
num[x]=num[x]+num[f];
return fa[x];
}
void merge(int a,int b)
{
int r1=find(a);
int r2=find(b);
fa[r1]=r2;
find(top[r2]);
num[r1]=num[top[r2]]+;
top[r2]=top[r1];
}
int main()
{
//freopen("no.txt","w",stdout);
scanf("%d",&m);
int x,y;
for(int i=;i<=;i++)
fa[i]=top[i]=i;
for(int i=;i<=m;i++)
{
cin>>s;
if(s=='M')
{
scanf("%d%d",&x,&y);
if(find(x)==find(y))continue;
merge(x,y);
}
if(s=='C')
{
scanf("%d%d",&x,&y);
int r1=find(x);
int r2=find(y);
if(r1!=r2)printf("-1\n");
else printf("%d\n",max(num[x],num[y])-min(num[x],num[y])-);
}
}
return ;
}

poj 1988 Cube Stacking && codevs 1540 银河英雄传说(加权并茶几)的更多相关文章

  1. POJ 1988 Cube Stacking(并查集+路径压缩)

    题目链接:id=1988">POJ 1988 Cube Stacking 并查集的题目 [题目大意] 有n个元素,開始每一个元素自己 一栈.有两种操作,将含有元素x的栈放在含有y的栈的 ...

  2. POJ 1988 Cube Stacking( 带权并查集 )*

    POJ 1988 Cube Stacking( 带权并查集 ) 非常棒的一道题!借鉴"找回失去的"博客 链接:传送门 题意: P次查询,每次查询有两种: M x y 将包含x的集合 ...

  3. poj.1988.Cube Stacking(并查集)

    Cube Stacking Time Limit:2000MS     Memory Limit:30000KB     64bit IO Format:%I64d & %I64u Submi ...

  4. POJ 1988 Cube Stacking(带权并查集)

    Cube Stacking Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 23678   Accepted: 8299 Ca ...

  5. POJ 1988 Cube Stacking (种类并查集)

    题目地址:POJ 1988 这道题的查找合并的方法都能想的到,就是一点没想到,我一直天真的以为查询的时候,输入后能立即输出,这种话在合并的时候就要所有的结点值都要算出来,可是经过路径压缩之后,没办法所 ...

  6. [POJ 1988] Cube Stacking (带值的并查集)

    题目链接:http://poj.org/problem?id=1988 题目大意:给你N个方块,编号从1到N,有两种操作,第一种是M(x,y),意思是将x所在的堆放到y所在的堆上面. 第二种是C(x) ...

  7. POJ 1988 Cube Stacking 【带权并查集】

    <题目链接> 题目大意: 有几个stack,初始里面有一个cube.支持两种操作: 1.move x y: 将x所在的stack移动到y所在stack的顶部. 2.count x:数在x所 ...

  8. POJ 1988 Cube stacking【并查集高级应用+妙用deep数组】

    Description Farmer John and Betsy are playing a game with N (1 <= N <= 30,000)identical cubes ...

  9. POJ 1988 Cube Stacking

    题意:有编号为1~N的N个小木块,有两种操作 M x y 将木块x所在的堆放到木块y所在的堆的上面 C x 询问木块x下面有多少块木块 代码巧妙就巧妙在GetParent函数中在进行路径压缩的同时,也 ...

随机推荐

  1. javascript学习(知识点整理)

    有了这个代码,就可以在定义 中增加更多的控制了 后面会举例关于extjs定义的更多控制     此种方案可以解决定义时需要一些函数调用的情况 函数作用域和声明提前: 即由于js是解释性语言,在执行前会 ...

  2. Windows下命令行连接mysql及导入sql文件

    嗯,今天要把phpcms的模板放到服务器上,,,呃,phpMyAdmin死活连接不上数据库,这又是个神马情况无奈,又想到命令行了,好吧,最近喜欢上命令行了,不过这果然还是命令行强大啊,啊哈哈下面呢,我 ...

  3. 嵌入式学习笔记(虚拟机共享文件夹配置-Ubuntu系统中)

    最近在学习Linux的操作系统,使用的是虚拟机.由于一些文件需要在主机和虚拟机中都要编辑,如果可以使得文件共享,可以极大的提高工作效率! 配置共享文件的步骤如下: [第一步] 在虚拟机软件中设置 [第 ...

  4. jquery ajax用例样板

    $.ajax({ url: '${managerPath}/customer/updateOrder.do', type: 'POST', async: false, data: { id: date ...

  5. Ant快速入门(四)-----Ant的任务(Task)

    到目前为止,我们已经掌握了Ant生成文件的基本结构,以及<project.../>,<target.../>,<property.../>等元素的配置方式.而< ...

  6. 符合altium designer操作习惯的cadence快捷键设置

    本人开始学习画PCB的时候,用的都是protel,后来转投altium desinger,因为这两个软件上手快且大学里教的也就是这两种.但由于工作需要换成cadence,这就给我造成了很大的困扰,尤其 ...

  7. C语言学习笔记--字符串函数

    字符串函数 需要包含头文件#include<stdio.h> strlen strcmp strcpy strchr strstr strcasestr

  8. listview底部增加按钮

    View bottomView=getActivity().getLayoutInflater().inflate(R.layout.btn_my_course, null); myCourses = ...

  9. JSP前端总结

    一.C标签    一] <c:out value="..." default="..." escapeXml="true">   ...

  10. 基于单例使用ThreadLocal对多线程下数据的访问修改

    package cn.lyy.thread; import java.util.Random; /** * 基于单例模式的基础上,使用ThreadLocal为每一个进入的线程生成一个实例, * 用来对 ...