浅谈并查集:https://www.cnblogs.com/AKMer/p/10360090.html

题目传送门:https://www.luogu.org/problemnew/show/P2024

对于每个生物,我们都可以将其拆成三个点,一个是自己\(self\),一个是食物\(eat\),一个是天敌\(enemy\),然后对于每一句话我们分别判断:

如果\(x\)与\(y\)是同类:如果\(x_{eat}=y_{self}\)或\(y_{eat}=x_{self}\)则是假话,否则分别对应合并三个集合。

如果\(x\)吃\(y\):如果\(x_{self}=y_{self}\)或\(y_{eat}=x_{self}\)则是假话,否则就合并\(x_{eat}\)与\(y_{self}\),\(x_{enemy}\)与\(y_{eat}\),\(x_{self}\)与\(y_{enemy}\)

时间复杂度:\(O(\alpha{n})\)

空间复杂度:\(O(n)\)

代码如下:

  1. #include <cstdio>
  2. using namespace std;
  3. const int maxn=1.5e5+5;
  4. int n,m,ans;
  5. int fa[maxn];
  6. int read() {
  7. int x=0,f=1;char ch=getchar();
  8. for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;
  9. for(;ch>='0'&&ch<='9';ch=getchar())x=x*10+ch-'0';
  10. return x*f;
  11. }
  12. int find(int x) {
  13. if(fa[x]==x)return x;
  14. return fa[x]=find(fa[x]);
  15. }
  16. int main() {
  17. n=read(),m=read();
  18. for(int i=1;i<=n*3;i++)fa[i]=i;
  19. for(int i=1;i<=m;i++) {
  20. int opt=read(),a=read(),b=read();
  21. if(a>n||b>n) {ans++;continue;}
  22. if(opt==2&&a==b) {ans++;continue;}
  23. int a_self=find(a),a_eat=find(a+n),a_enemy=find(a+(n<<1));
  24. int b_self=find(b),b_eat=find(b+n),b_enemy=find(b+(n<<1));
  25. if(opt==1) {
  26. if(a_eat==b_self||b_eat==a_self) {ans++;continue;}
  27. fa[a_self]=b_self,fa[a_eat]=b_eat,fa[a_enemy]=b_enemy;
  28. }
  29. else {
  30. if(a_self==b_self||b_eat==a_self) {ans++;continue;}
  31. fa[a_eat]=b_self,fa[a_self]=b_enemy,fa[a_enemy]=b_eat;
  32. }
  33. }
  34. printf("%d\n",ans);
  35. return 0;
  36. }

洛谷【P2024】[NOI2001]食物链的更多相关文章

  1. 洛谷 P2024 [NOI2001]食物链 解题报告

    P2024 [NOI2001]食物链 题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个 ...

  2. 洛谷 P2024 [NOI2001]食物链 (并查集)

    嗯... 题目链接:https://www.luogu.org/problemnew/show/P2024 这道题和团伙这道题的思想比较类似,都是一个数组分成几个集合,但这道题的思路更加混乱,建议没做 ...

  3. 洛谷 P2024 [NOI2001]食物链

    题意简述 有人用两种说法对这 N 个动物所构成的食物链关系进行描述: 1."1 X Y",表示 X 和 Y 是同类. 2."2 X Y",表示 X 吃 Y . ...

  4. 洛谷 P2024 [NOI2001]食物链(种类并查集,加权并查集)

    传送门 解题思路 加权并查集: 什么是加权并查集? 就是记录着每个节点到它的父亲的信息(权值等). 难点:在路径压缩和合并节点时把本节点到父亲的权值转化为到根节点的权值 怎么转化呢? 每道题都不一样Q ...

  5. 洛谷 P2024 [NOI2001]食物链——带权值的并查集维护

    先上一波题目 https://www.luogu.org/problem/P2024 通过这道题复习了一波并查集,学习了一波带权值操作 首先我们观察到 所有的环都是以A->B->C-> ...

  6. Java实现 洛谷 P2024 [NOI2001]食物链

    输入输出样例 输入 #1 100 7 1 101 1 2 1 2 2 2 3 2 3 3 1 1 3 2 3 1 1 5 5 输出 #1 3 import java.util.Scanner; pub ...

  7. [洛谷P2024/POJ1182]食物链 - 带偏移量的并查集(2)

    Description 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个动物都是 A,B,C 中的 ...

  8. 种族并查集模板题分析 -----P2024 [NOI2001]食物链

    本文参考了:洛谷p2024题解 题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个动物都 ...

  9. 洛谷 P4017 最大食物链计数

    洛谷 P4017 最大食物链计数 洛谷传送门 题目背景 你知道食物链吗?Delia生物考试的时候,数食物链条数的题目全都错了,因为她总是重复数了几条或漏掉了几条.于是她来就来求助你,然而你也不会啊!写 ...

  10. 【题解】P2024 [NOI2001]食物链 - 数据结构 - 并查集

    P2024 [NOI2001]食物链 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 动物王国中有三类动物 \(A,B ...

随机推荐

  1. $.proxy() 的妙用

    $.proxy() 最主要就是用来修改函数执行时的上下文对象的. 先看以下情景: <div id="panel" style="display:none;" ...

  2. 8位单片机可用的 mktime localtime函数

    8位单片机可用的 mktime  localtime函数及源码 最近在做一个8位单片机项目,其中用到了时间戳转换函数,这个在32位机上一个库函数就解决了问题,没想到在8位单片机中没有对应库(time. ...

  3. perl FAQ(zz)

    1. Why do you write a program in Perl? Ans : Easy to use and fast execution since perl script underg ...

  4. Kubernetes Kubeadm部署集群

    Kubernetes高可用架构 Kubenetes 2个高可用核心 apiserver.etcd etcd:集群数据中心,需要保持高可用,用于存放集群的配置信息.状态信息及Pod等信息.如果数据丢失集 ...

  5. .NET及JAVA 中如何使用代码启动程序

    .NET 中: System.Diagnostics.Process.Start("应用程序");    JAVA中: ProcessBuilder pb=new ProcessB ...

  6. Bluetooth Profile for iPhone from the functional perspectives

    Classic Bluetooth Profile for iPhone from the functional perspectives Function Description BT Profil ...

  7. Java基础(7)-集合类3

    list集合的特点 1)有序(存储和取出的元素一直) 2)可重复 List子类的特点 ArrayList 有序,可重复 底层数据结构是数组 查询快,增删慢 线程不安全,效率高 Vector 有序,可重 ...

  8. Ubuntu 没有mkinitrd 解决方法

    1. 先apt-get install  先装cramfsprogs 2. http://archive.debian.net/zh-cn/sarge/initrd-tools 下载initrd-to ...

  9. Educational Codeforces Round 15 A, B , C 暴力 , map , 二分

    A. Maximum Increase time limit per test 1 second memory limit per test 256 megabytes input standard ...

  10. Aix-Linux查看系统信息

    1.查看内存.磁盘等使用情况 命令:nmon 输入命令nmon之后,按M键memory,N键NetWork,J键查看目录使用情况. 2.查看防火墙 命令:smit 输入之后按照图形化操作 Commun ...