因为是中文题,题意就不说了,直接说思路

我们不知道给的说法中的动物属于A B C哪一类,所以我们可以用不同区间的数字表示这几类动物,这并不影响结果,我们可以用并查集把属于一类的动物放在一块,举个例子:

A    2*n ~ 3*n-1

B    n ~ 2*n-1

C   0 ~ n-1

假设 n =10,1和3是同类,那么1和3并到一块,11和13并到一块,21和23并到一块。那么这样既不相互矛盾,又把这三种动物的可能性列举了出来。1捕食4,那么说明1比4高了一个等级,将1和14归并为一类,11和24归并为一类,21和4归并为一类,即B吃C,A吃B,C吃A。

看代码:

  1. #include<stdio.h>
  2. int f[160001];
  3. int getf(int v)
  4. {
  5. if(f[v]==v)
  6. return v;
  7. return f[v]=getf(f[v]);
  8. }
  9. void marge(int u,int v)
  10. {
  11. int t1=getf(u),t2=getf(v);
  12. if(t1!=t2)
  13. f[t2]=t1;
  14. }
  15. bool same(int u,int v)
  16. {
  17. int t1=getf(u),t2=getf(v);
  18. if(t1!=t2)
  19. return 0;
  20. return 1;
  21. }
  22. int main()
  23. {
  24. //A 2*n ~ 3*n-1
  25. //B n ~ 2*n-1
  26. //C 0~ n-1
  27. int n,m,sum,a,b,p;
  28. scanf("%d%d",&n,&m);
  29. for(int i=0; i<n*3+10; i++)
  30. f[i]=i;
  31. sum=0;
  32. for(int i=0; i<m; i++)
  33. {
  34. scanf("%d%d%d",&p,&a,&b);
  35. a-=1,b-=1;
  36. if(a>=n||b>=n||b<0||a<0)
  37. {
  38. sum++;
  39. continue;
  40. }
  41. if(p==1)
  42. {
  43. if(same(a,b+n)||same(a,b+2*n))//a和b不能有捕食和被捕食的关系
  44. sum++;
  45. else
  46. {
  47. marge(a,b);//同一等级
  48. marge(a+n,b+n);
  49. marge(a+2*n,b+2*n);
  50. }
  51. }
  52. else if(p==2)
  53. {
  54. if(same(a,b)||same(a,b+2*n))//a和不能是同类 也不能是b捕食a
  55. sum++;
  56. else//a捕食b表示a和b+n是同一等级
  57. {
  58. marge(a,b+n);
  59. marge(a+n,b+2*n);
  60. marge(a+2*n,b);
  61. }
  62. }
  63. }
  64. printf("%d\n",sum);
  65. return 0;
  66. }

poj——1182食物链 并查集(提升版)的更多相关文章

  1. POJ 1182 食物链 [并查集 带权并查集 开拓思路]

    传送门 P - 食物链 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit  ...

  2. poj 1182 食物链 并查集 题解《挑战程序设计竞赛》

    地址 http://poj.org/problem?id=1182 题解 可以考虑使用并查集解决 但是并不是简单的记录是否同一组的这般使用 每个动物都有三个并查集 自己 天敌 捕食 并查集 那么在获得 ...

  3. POJ 1182 食物链(并查集的使用)

    食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 81915   Accepted: 24462 Description ...

  4. poj 1182 食物链 并查集的又一个用法

    食物链   Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 41584   Accepted: 12090 Descripti ...

  5. POJ 1182食物链(并查集)

    食物链Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 85474 Accepted: 25549Description动物王国中有三 ...

  6. POJ - 1182 食物链 并查集经典

    思路:设r(x)表示节点x与根结点的关系,px表示x的根结点.记录每个节点与其父节点的关系,就能很方便知道每个节点以及和它的父节点的关系. struct node{ int par; //父亲节点 i ...

  7. POJ 1182 食物链 (并查集)

    食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 50601   Accepted: 14786 Description ...

  8. POJ 1182 食物链(并查集)

    题目链接 经过宝哥的讲解,终于对这种问题有了进一步的理解.根据flag[x]和flag[y]求flag[tx]是最关键的了. 0吃1,1吃2,2吃0. 假设flag[tx] = X; 那么X + fl ...

  9. poj 1182 (关系并查集) 食物链

    题目传送门:http://poj.org/problem?id=1182 这是一道关系型并查集的题,对于每个动物来说,只有三种情况:同类,吃与被吃: 所以可以用0,1,2三个数字代表三种情况,在使用并 ...

随机推荐

  1. python xlwings Excel 内容截图

    import xlwings as xw from PIL import ImageGrab def excel_save_img(path, sheet=0, img_name="1&qu ...

  2. PyQt5之QtMultimedia模块音乐播放没声音已解决

    昨天用PyQt5的QtMultimedia模块播放音乐时,单独使用可播放,放代码里结合使用死的播放不了.以下是测试demo可播放代码: # -*- coding: utf-8 -*- # Nola f ...

  3. harbor自动清理镜像

    harbor定时清理镜像 ​ 分享下最近写harbor仓库镜像自动清理脚本思路,很长时间不写shell脚本,这次的脚本也是匆匆写的,还有很多可优化点,感兴趣的可以参考自己优化下,写的不完善地方也希望指 ...

  4. 7-41 jmu-python-最佳身高 (10 分)

    最佳的情侣身高差遵循着一个公式:(女方的身高)×1.09 =(男方的身高).下面就请你写个程序,为任意一位用户计算他/她的情侣的最佳身高. 输入格式: 输入第一行给出正整数N(≤10),为前来查询的用 ...

  5. JUC-八锁现象和不安全锁

    1,被 synchronized 修饰的方法,锁的对象是方法的调用者(实例对象) 2,被 static 修饰的方法,锁的对象就是 Class模板对象,这个则全局唯一 问题7: 一个普通同步方法,一个静 ...

  6. iview中遇到table的坑(已经修改了table的数据,但是界面没有更新)

    https://blog.csdn.net/bigdargon/article/details/89381466 https://blog.csdn.net/qiuyan_f/article/deta ...

  7. Nginx之负载均衡配置(二)

    前文我们聊到了nginx作为负载均衡的配置,前端nginx作为调度器调度http或https请求,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/12458159 ...

  8. DEV GridControl控件使用(CheckBox全选、操作按钮、事件处理,获取值)

    1.GridControl控件使用 (1)绑定数据源 //绑定DataTable gridControl1.DataSource = DbHelper.ExecuteDataTable("S ...

  9. LeetCode 41,一题解读in-place思想

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是LeetCode题解系列第21篇,今天来看一道人狠话不多的题目. 题面 题目非常简单,只有一句话,给定一个整数数组,要求返回最小的不在 ...

  10. ES6—get 与 set

    在类里面可以去定义一些getter和setter,getter可以得到一些东西的方法,setter可以设置东西 class Chef{ constructor(food){ this.food = f ...