本文主要是介绍HDU - 3635 Dragon Balls,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
HDU - 3635 Dragon Balls
1.题面
传送门
2.解题思路
要求给出在一个并查集的元素中,每个元素在哪个集合中,该元素所在的集合中有几个元素,该元素参与了几次合并操作。我的并查集自然支持前两个操作。后一个操作实际上询问的是在一个并查集中某个元素到祖先的距离是多少。某个节点的移动次数等于自己父亲节点的移动次数+1,可以使用和记录集合个数一样的方法来记录。这里用的是暴力数的方法,而且没有使用路径压缩,有水过去的嫌疑
3.解题代码
/*****************************************************************> File Name: tmp.cpp> Author: Uncle_Sugar> Mail: uncle_sugar@qq.com> Created Time: 2016年02月19日 星期五 09时45分39秒****************************************************************/
# include <cstdio>
# include <cstring>
# include <cmath>
# include <cstdlib>
# include <iostream>
# include <iomanip>
# include <set>
# include <map>
# include <vector>
# include <stack>
# include <queue>
using namespace std;const int debug = 1;
const int size = 10000 + 10;
typedef long long ll;struct DisjointSet{int *T,size,sum;int FindRoot(int i){return T[i] < 0 ? i : FindRoot(T[i]);}DisjointSet(){}DisjointSet(int _size):size(_size){T = new int[size];Init();}void Init(){sum = size;memset(T,-1,sizeof(int)*size);}bool Unioned(int i,int j){return FindRoot(i)==FindRoot(j);}void Union(int i,int j){if ( (i = FindRoot(i) ) != ( j = FindRoot(j) ) ){T[i] = T[i] + T[j];T[j] = i;sum--;}}int GetSum(int i){return -T[FindRoot(i)];}
};DisjointSet dst(size);
int TransTime[size];void Transport(){int a,b;cin >> a >> b;dst.Union(b,a);
}void Query(){int x,d=0;cin >> x;while (dst.T[x]>=0){x = dst.T[x];d++;}cout << x << " " << -dst.T[x] << " " << d << '\n';
}
int main()
{std::ios::sync_with_stdio(false);cin.tie(0);int i,j,k;int T,ncase=0;cin >> T;while (T--){cout << "Case " << (++ncase) << ":\n";int n,q;memset(TransTime,0,sizeof(TransTime));dst.Init();cin >> n >> q;char cmd[10];while (q--){cin >> cmd;switch(cmd[0]){case 'T':Transport();break;case 'Q':Query();break;}}}return 0;
}
这篇关于HDU - 3635 Dragon Balls的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!