hdu 3635 Dragon Balls(并查集技巧)

题意:n个点m次询问,两种操作:1.将含有龙珠i的集合加入含有龙珠j的集合中;2.查询龙珠i所在堆的编号,龙珠个数,龙珠i的搬运次数;

思路:并查集,数组分别维护关系、数量、搬运次数;

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n,m;
int fa[500010],time[500010],num[500010];
void init()
{
    for(int i=0;i<=n;i++)
    {
        fa[i]=i;num[i]=1;time[i]=0;
    }
}
int fin(int x)
{
    if(fa[x]==x) return x;
    int j=fa[x];
    fa[x]=fin(fa[x]);
    time[x]+=time[j];//累加搬移次数
    return fa[x];
}
void combine(int a,int b)
{
    int t1=fin(a);
    int t2=fin(b);
    if(t1!=t2)
    {
        fa[t1]=t2;
        num[t2]+=num[t1];//两个集合中的个数合并
        time[t1]=1;//搬移次数置1
    }
}
int main()
{
    char ch[5];
    int i,j,k,t,a,b;
    scanf("%d",&t);
    for(j=1;j<=t;j++)
    {
        printf("Case %d:\n",j);
        scanf("%d%d",&n,&m);
        init();
        for(i=0;i<m;i++)
        {
            scanf("%s",ch);
            if(ch[0]==‘T‘)
            {
                scanf("%d%d",&a,&b);
                combine(a,b);//合并
            }
            else
            {
                scanf("%d",&a);
                int r=fin(a);
                printf("%d %d %d\n",r,num[r],time[a]);
            }
        }
    }
    return 0;
}
时间: 2024-10-13 23:57:11

hdu 3635 Dragon Balls(并查集技巧)的相关文章

HDU 3635 Dragon Balls(并查集)

Dragon Balls Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submission(s) : 64   Accepted Submission(s) : 26 Font: Times New Roman | Verdana | Georgia Font Size: ← → Problem Description Five hundred years later

HDU 3635 Dragon Balls 七龙珠 Union Find算法

孙悟空要寻找七龙珠,这回是七龙珠的增强版了,因为这些龙珠会衍生,最后不止七颗龙珠了. 悟空带着布玛的龙珠雷达探测器出发了,却发现布玛的龙珠雷达探测器的程序太垃圾了,所以找到我们这些ACM高手为龙珠雷达探测器写个程序,要求可以显示某颗龙珠所在的城市的位置,该龙珠所在的城市共有多少颗龙珠,龙珠移动过的次数. 布玛是个有钱人啊,写个程序我要价5百万,不算过分吧.因为本程序需要用到Union Find(并查集)算法,而且最困难的部分是如何压缩路径,不压缩路径自然容易做到,要压缩路径可以使得程序加快很多,

测试赛F - Dragon Balls(并查集)

F - Dragon Balls Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Description Five hundred years later, the number of dragon balls will increase unexpectedly, so it's too difficult for Monkey King(WuKong) to

hdu 3635 Dragon Balls(并查集应用)

Problem Description Five hundred years later, the number of dragon balls will increase unexpectedly, so it's too difficult for Monkey King(WuKong) to gather all of the dragon balls together. His country has N cities and there are exactly N dragon bal

HDU 3635 Dragon Balls(带权并查集)

题目地址:HDU 3635 加权并查集水题. 用num数组维护该城市有多少龙珠,用times数组维护每个龙珠运输了多少次.num数组在合并的时候维护.times数组由于每个都不一样,所以要在找根的时候递归来全部维护. 最终,x龙珠所在的城市就是x节点所在的根,x结点所在的跟的num数组值是该城市的龙珠数.times[x]为该龙珠运输了多少次. 代码如下: #include <iostream> #include <cstdio> #include <string> #i

hdu 3635 Dragon Balls 【基础带权并查集】

Dragon Balls Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 3461    Accepted Submission(s): 1348 Problem Description Five hundred years later, the number of dragon balls will increase unexpect

HDU 3635 Dragon Balls (并查集)

Dragon Balls Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 3360    Accepted Submission(s): 1303 Problem Description Five hundred years later, the number of dragon balls will increase unexpect

HDU 3635 Dragon Balls(并查集--路径压缩拓展应用)

题目大意: 初始时,有n个龙珠,编号从1到n,分别对应的放在编号从1到n的城市中. 现在又2种操作: T A B,表示把A球所在城市全部的龙珠全部转移到B城市.(第一次时,因为A球所在的城市只有一个球,所以只移动1个,如果有多个,则全部移动). Q A,表示查询A.要求得到的信息分别是:A现在所在的城市,A所在城市的龙珠数目,A转移到该城市移动的次数(如果没有移动就输出0) 思路:并查集,难点在于求龙珠的转移次数,可以在路径压缩的过程中沿着递归路径累加. //Accepted 1740 KB 5

HDU 3635 Dragon Balls

题意: 一开始每个城市里有一个龙珠  每次T操作使得A龙珠所在城市的所有龙珠飞到B龙珠所在城市  Q操作询问X龙珠在哪个城市  那个城市里有几个龙珠  X飞过几次 思路: 从T操作的功能来看想到并查集  即  每次找到所在城市(找根)飞到另一个城市(并集) 但是并查集无法统计每个龙珠飞过几次  这时候我们可以给并查集加上一个权值 每次飞的时候使A集合的权值++  这样当询问X飞过几次的时候  只需要从X开始找根  并把路径上的权值求和即可 代码: #include<cstdio> #inclu