题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1370

题意:

  在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足:

    (1)我朋友的朋友是我的朋友。

    (2)我敌人的敌人是我的朋友。

  所有是朋友的人组成一个团伙。

  告诉你关于这n个人的m条信息,即某两个人是朋友,或者某两个人是敌人。

  请你编写一个程序,计算出这个城市最多可能有多少个团伙。

题解:

  对于一个人a,建两个点a和a+n。

  a+n实际上并不存在,只起到连接的作用,是一个虚点。

  所有与a相连的点都是a的朋友。

  所有与a+n相连的点都是它的敌人。

  如果x和y是朋友,则合并(x,y)。

  如果x和y是敌人,则合并(x,y+n)和(y,x+n)。

  所有在一个集合内的人,都属于同一个团伙。

  统计一下有多少个集合,至少包含一个在[1,n]内的点,即为答案。

AC Code:

  1. #include <iostream>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #define MAX_N 2005
  5.  
  6. using namespace std;
  7.  
  8. int n,m;
  9. int ans=;
  10. int par[MAX_N];
  11. bool vis[MAX_N];
  12.  
  13. void init_union_find()
  14. {
  15. for(int i=;i<=n*;i++)
  16. {
  17. par[i]=i;
  18. }
  19. }
  20.  
  21. int find(int x)
  22. {
  23. return par[x]==x?x:par[x]=find(par[x]);
  24. }
  25.  
  26. void unite(int x,int y)
  27. {
  28. int px=find(x);
  29. int py=find(y);
  30. if(px==py) return;
  31. par[px]=py;
  32. }
  33.  
  34. bool same(int x,int y)
  35. {
  36. return find(x)==find(y);
  37. }
  38.  
  39. void read()
  40. {
  41. cin>>n>>m;
  42. init_union_find();
  43. int x,y;
  44. char p;
  45. for(int i=;i<m;i++)
  46. {
  47. cin>>p>>x>>y;
  48. if(p=='F') unite(x,y);
  49. else
  50. {
  51. unite(x+n,y);
  52. unite(y+n,x);
  53. }
  54. }
  55. }
  56.  
  57. void solve()
  58. {
  59. memset(vis,false,sizeof(vis));
  60. for(int i=;i<=n;i++)
  61. {
  62. int p=find(i);
  63. if(!vis[p])
  64. {
  65. vis[p]=true;
  66. ans++;
  67. }
  68. }
  69. }
  70.  
  71. void print()
  72. {
  73. cout<<ans<<endl;
  74. }
  75.  
  76. int main()
  77. {
  78. read();
  79. solve();
  80. print();
  81. }

BZOJ 1370 [Baltic2003]Gang团伙:并查集【虚点】的更多相关文章

  1. BZOJ 1370: [Baltic2003]Gang团伙 [并查集 拆点 | 种类并查集WA]

    题意: 朋友的朋友是朋友,敌人的敌人是朋友:朋友形成团伙,求最多有多少团伙 种类并查集WA了一节课,原因是,只有那两种关系才成立,诸如朋友的敌人是朋友之类的都不成立! 所以拆点做吧 #include ...

  2. BZOJ 1370: [Baltic2003]Gang团伙(luogu 1892)(种类并查集)

    题面: bzoj题面有误,还是看luogu的吧 https://www.luogu.org/problemnew/show/P1892 题解: 种类并查集.. 因为有敌人的敌人是朋友这个条件,所以需要 ...

  3. [BZOJ1370][Baltic2003]Gang团伙 并查集+拆点

    Description 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足: 1. 我朋友的朋友是我的朋友: 2. 我敌人的敌人是我的朋友: 所有是朋友的人组成一个团伙.告诉你关于这n个 ...

  4. 【bzoj1370】[Baltic2003]Gang团伙 并查集

    题目描述 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足: 1. 我朋友的朋友是我的朋友: 2. 我敌人的敌人是我的朋友: 所有是朋友的人组成一个团伙.告诉你关于这n个人的m条信息, ...

  5. [BZOJ1370][Baltic2003]Gang团伙

    [BZOJ1370][Baltic2003]Gang团伙 试题描述 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足: 1. 我朋友的朋友是我的朋友: 2. 我敌人的敌人是我的朋友: ...

  6. BZOJ.2054.疯狂的馒头(并查集)

    BZOJ 倒序处理,就是并查集傻题了.. 并查集就是确定下一个未染色位置的,直接跳到那个位置染.然而我越想越麻烦=-= 以为有线性的做法,发现还是要并查集.. 数据随机线段树也能过去. //18400 ...

  7. PAT甲题题解-1034. Head of a Gang (30)-并查集

    给出n和k接下来n行,每行给出a,b,c,表示a和b之间的关系度,表明他们属于同一个帮派一个帮派由>2个人组成,且总关系度必须大于k.帮派的头目为帮派里关系度最高的人.(注意,这里关系度是看帮派 ...

  8. 2021.08.03 BZOJ 疯狂的馒头(并查集)

    2021.08.03 BZOJ 疯狂的馒头(并查集) 疯狂的馒头 - 题目 - 黑暗爆炸OJ (darkbzoj.tk) 重点: 1.并查集的神奇运用 2.离线化 题意: 给一个长为n的序列,进行m次 ...

  9. Codevs 2597 团伙(并查集)

    2597 团伙 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 传送门 题目描述 Description 1920年的芝加哥,出现了一群强盗.如果两个强盗遇上了,那么 ...

随机推荐

  1. Free Code Camp社区对数百计编程学习者进行的统计希望告诉你什么?

    文章来源:https://www.sdk.cn/news/5044 著名编程学习社区Free Code Camp对超过1.5万名编程学习者进行了调查.其中有一个问题为:“你对哪个编程职位最感兴趣?”有 ...

  2. java类库中的设计模式

    原帖:http://stackoverflow.com/questions/1673841/examples-of-gof-design-patterns 提问:我正在学习GoF的<设计模式&g ...

  3. type-c UCSI和UcmCx.sys文件

    简介:https://docs.microsoft.com/zh-cn/windows-hardware/drivers/usbcon/ucsi UCSI:USB Type-C Connector S ...

  4. 常用string函数分析

    string函数分析string函数包含在string.c文件中,经常被C文件使用.1. strcpy函数原型: char* strcpy(char* str1,char* str2);函数功能: 把 ...

  5. JS常用方法手记

    1.判断arr数组是否含有元素str,没有返回-1 arr.indexOf(str) 2.遍历arr数组,k为键,v为值 arr.map((v, k) => { return;}) 3.arr数 ...

  6. UIScrollView奇葩不滑动

    首先要说声尼玛,真奇葩,从来都没有遇到过这个问题,首先描述一下背景: 我是用XIB拖拽了一个UIScrollView在View上,然后设置了frame,在ViewDidLoad里面,设置了scroll ...

  7. GS踢玩家下线功能

    GS踢玩家下线功能 //key:userId, val:nChannelId (当前在线用户) std::map<int, int> m_mapOnLineUserByUid; ///&l ...

  8. 兼容性强、简单、成熟、稳定的RTMPClient客户端拉流功能组件EasyRTMPClient

    EasyRTMPClient EasyRTMPClient拉流功能组件是EasyDarwin流媒体团队开发.提供和维护的一套非常稳定.易用.支持重连的RTMPClient工具,SDK形式提供,全平台支 ...

  9. 基于Darwin实现的分布式流媒体直播服务器系统

    各位EasyDarwin开源项目的爱好者,您好,这篇博客的年限有点老了,目前EasyDarwin已经采用全新的云平台架构,详细可以参考博客:http://blog.csdn.net/xiejiashu ...

  10. A good example is a User-Agent switcher which changes User-Agent on every request:

    Configuration | Colly http://go-colly.org/docs/introduction/configuration/