L3-003. 社交集群

时间限制
1000 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

在社交网络平台注册时,用户通常会输入自己的兴趣爱好,以便找到和自己兴趣相投的朋友。有部分兴趣相同的人们就形成了“社交集群”。现请你编写程序,找出所有的集群。

输入格式:

输入的第一行给出正整数N(<=1000),即社交网络中的用户总数(则用户从1到N编号)。随后N行,每行按下列格式列出每个人的兴趣爱好:

Ki: hi[1] hi[2] ... hi[Ki]

其中Ki(>0)是第i个人的兴趣的数量,hi[j]是第i个人的第j项兴趣的编号,编号范围为[1, 1000]内的整数。

输出格式:

首先在第一行输出整个网络中集群的数量,然后在第二行按非递增的顺序输出每个集群中用户的数量。数字间以1个空格分隔,行首尾不得有多余空格。

输入样例:

  1. 8
  2. 3: 2 7 10
  3. 1: 4
  4. 2: 5 3
  5. 1: 4
  6. 1: 3
  7. 1: 4
  8. 4: 6 8 1 5
  9. 1: 4

输出样例:

  1. 3
  2. 4 3 1

似乎挺简单的跟Suspects一样的题目,一遍水过

代码:

  1. #include<iostream>
  2. #include<algorithm>
  3. #include<cstdlib>
  4. #include<sstream>
  5. #include<cstring>
  6. #include<cstdio>
  7. #include<string>
  8. #include<deque>
  9. #include<stack>
  10. #include<cmath>
  11. #include<queue>
  12. #include<set>
  13. #include<map>
  14. #define INF 0x3f3f3f3f
  15. #define MM(x) memset(x,0,sizeof(x))
  16. using namespace std;
  17. typedef long long LL;
  18. const int N=1010;
  19. vector<int>person[N];
  20. map<int,vector<int> >belong;
  21. int pre[N],ran[N],r[N];
  22. void init()
  23. {
  24. for (int i=0; i<N; i++)
  25. {
  26. person[i].clear();
  27. pre[i]=i;
  28. ran[i]=1;
  29. }
  30. belong.clear();
  31. MM(r);
  32. }
  33. inline int find(int n)
  34. {
  35. if(n!=pre[n])
  36. return pre[n]=find(pre[n]);
  37. return pre[n];
  38. }
  39. inline int joint(int a,int b)
  40. {
  41. int fa=find(a),fb=find(b);
  42. if(fa==fb)
  43. return 0;
  44. if(fa>=fb)
  45. {
  46. pre[fb]=fa;
  47. ran[fa]+=ran[fb];
  48. ran[fb]=0;
  49. return 1;
  50. }
  51. else
  52. {
  53. pre[fa]=fb;
  54. ran[fb]+=ran[fa];
  55. ran[fa]=0;
  56. return 1;
  57. }
  58. }
  59. bool cmp(const int &a,const int &b)
  60. {
  61. return a>b;
  62. }
  63. int main(void)
  64. {
  65. int n,i,j,h,a,b,m,k;
  66. while (~scanf("%d",&n))
  67. {
  68. init();
  69. for (i=1; i<=n; i++)
  70. {
  71. scanf("%d:",&m);
  72. for (j=1; j<=m; j++)
  73. {
  74. scanf("%d",&h);
  75. person[i].push_back(h);
  76. belong[h].push_back(i);
  77. }
  78. }
  79.  
  80. for (i=1; i<=n; ++i)
  81. {
  82. for (j=0; j<person[i].size(); ++j)
  83. {
  84. int hobb=person[i][j];
  85. for (k=0; k<belong[hobb].size(); k++)
  86. {
  87. int oth=belong[hobb][k];
  88. joint(i,oth);
  89. }
  90. }
  91. }
  92. int cnt=0;
  93. for (i=1; i<=n; i++)
  94. {
  95. if(ran[i]!=0)
  96. r[cnt++]=ran[i];
  97. }
  98. sort(r,r+cnt,cmp);
  99. printf("%d\n",cnt);
  100. for (i=0; i<cnt; i++)
  101. printf("%d%s",r[i],i==cnt-1?"\n":" ");
  102. }
  103. return 0;
  104. }

PAT天梯赛练习题——L3-003. 社交集群(并查集按秩合并)的更多相关文章

  1. PAT天梯赛练习题——L3-004. 肿瘤诊断(三维连通块并查集)

    L3-004. 肿瘤诊断 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 在诊断肿瘤疾病时,计算肿瘤体积是很重要的一环.给定病灶 ...

  2. PAT天梯赛练习题——L3-007. 天梯地图(多边权SPFA)

    L3-007. 天梯地图 时间限制 300 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 本题要求你实现一个天梯赛专属在线地图,队员输入自己学校 ...

  3. 天梯L3-003. 社交集群——并查集

    在社交网络平台注册时,用户通常会输入自己的兴趣爱好,以便找到和自己兴趣相投的朋友.有部分兴趣相同的人们就形成了“社交集群”.现请你编写程序,找出所有的集群. 输入格式: 输入的第一行给出正整数N(&l ...

  4. PAT天梯赛练习题 L2-013 红色警报(并查集+逆序加边)

    L2-013. 红色警报 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 战争中保持各个城市间的连通性非常重要.本题要求你编写一 ...

  5. PAT天梯赛练习题 L3-010. 是否完全二叉搜索树(完全二叉树的判断)

    L3-010. 是否完全二叉搜索树 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 将一系列给定数字顺序插入一个初始为空的二叉搜 ...

  6. PAT天梯赛练习题 L3-002. 堆栈(线段树查询第K大值或主席树)

    L3-002. 堆栈 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 大家都知道“堆栈”是一种“先进后出”的线性结构,基本操作有 ...

  7. PAT天梯赛练习题 L3-011. 直捣黄龙(多关键字SPFA+DFS)

    L3-011. 直捣黄龙 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 本题是一部战争大片 —— 你需要从己方大本营出发,一路 ...

  8. PAT天梯赛练习题——L3-005. 垃圾箱分布(暴力SPFA)

    L3-005. 垃圾箱分布 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 大家倒垃圾的时候,都希望垃圾箱距离自己比较近,但是谁 ...

  9. PAT天梯赛练习题——L3-008. 喊山(邻接表+BFS)

    L3-008. 喊山 时间限制 150 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 喊山,是人双手围在嘴边成喇叭状,对着远方高山发出“喂—喂喂 ...

随机推荐

  1. 解析没有key的Json

    没有key的Json,例如:["http://www.cnblogs.com/Cherry-B/p/4625133.html","http://www.cnblogs.c ...

  2. Java中枚举类型Enum的一种使用方式

    枚举类定义如下: public enum Status { SCUUESS("1", "成功"), FAILED("2", "失败 ...

  3. NSString+TimeCategory

    NSString+TimeCategory.h //------------------------------------------------ #import <foundation fo ...

  4. Unity3d中MonoBehavior默认函数的执行顺序和生命周期

    Awake()在MonoBehavior创建后就立刻调用,在脚本实例的整个生命周期中,Awake函数仅执行一次:如果游戏对象(即gameObject)的初始状态为关闭状态,那么运行程序,Awake函数 ...

  5. SSave ALAsset image to disk fast on iOS

    I am using ALAsset to retrieve images like that: [[asset defaultRepresentation] fullResolutionImage] ...

  6. Synchronized关键字整理

    Synchronized关键字整理 作用:能够保证在同一时刻最多只有一个线程执行该段代码,以达到保证并发安全效果. 两个用法: 1.对象锁: 包括方法锁(默认锁对象为this当前实例对象)和同步代码块 ...

  7. Java中System.setProperty()

    Java中System.setProperty()用法 <转抄> // Daysafter :Integer中 getInteger( String s); getInteger( Str ...

  8. 在Phonegap下实现oAuth认证

    原文:http://www.kuqin.com/mobile/20120719/322873.html 前段时间做过两次关于Phonegap的现场交流会议分享.基本上把Phonegap的一些特性和大家 ...

  9. 移动产品设计之ios系统的导航

    做道题:[不定项选择题] OS中导航设计模式有几种? A.平铺导航 B.标签导航 C.树形导航 D.模态视图导航 正确答案:A B C 讲解: 导航始终是产品设计的重头戏,往往产品设计中90%的事情就 ...

  10. Mac电脑怎么显示隐藏文件、xcode清除缓存

    1.删除Xcode中多余的证书provisioning profile 手动删除: Xcode6 provisioning profile path: ~/Library/MobileDevice/P ...