【题解】P2024 [NOI2001]食物链 - 数据结构 - 并查集
P2024 [NOI2001]食物链
声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。
题目描述
动物王国中有三类动物 \(A,B,C\),这三类动物的食物链构成了有趣的环形。\(A\) 吃 \(B\),\(B\) 吃 \(C\),\(C\) 吃 \(A\)。
现有 \(N\) 个动物,以 \(1 - N\) 编号。每个动物都是 \(A\) , \(B\) , \(C\) 中的一种,但是我们并不知道它到底是哪一种。
有人用两种说法对这 \(N\) 个动物所构成的食物链关系进行描述:
第一种说法是 \(“1 \ X \ Y”\) ,表示 \(X\) 和 \(Y\) 是同类。
第二种说法是 \(“2 \ X \ Y”\) ,表示 \(X\) 吃 \(Y\) 。
此人对 \(N\) 个动物,用上述两种说法,一句接一句地说出 \(K\) 句话,这 \(K\) 句话有的是真的,有的是假的。当一句话满足下列三条之一时,这句话就是假话,否则就是真话。
• 当前的话与前面的某些真的话冲突,就是假话
• 当前的话中 \(X\) 或 \(Y\) 比 \(N\) 大,就是假话
• 当前的话表示 \(X\) 吃 \(X\),就是假话
你的任务是根据给定的 \(N\) 和 \(K\) 句话,输出假话的总数。
Solution
接触并查集已经有好一段时间了,但还是第一次见这种(我太菜了
在同一个并查集中的元素并不一定代表它们是同一种,而是代表它们之间有关系
于是就用一个 \(3\) 倍的并查集来写
设 \(1\ -\ n\) 吃 \(n+1\ -\ 2*n\) ,\(n+1\ -\ 2*n\) 吃 \(2 * n + 1\ -\ 3 * n\) ,\(2 *n + 1\ -\ 3 * n\) 吃 \(1\ -\ n\)
由于只需知道它们之间的关系,而固定是 \(A\ B\ C\) 哪一个集合并不重要,所以在连边时要把三个集合中每个都连起来
\(eg:\ n = 5\) 时,\(2\) 吃 \(3\),则要把 \(2\) 和 \(3 + 5\) ,\(2 + 5\) 和 \(3 + 2 * 5\) ,\(2 + 2 * 5\) 和 \(3\) 都连起来
这里可以参照这篇博客 , 我觉得有他画的图就很容易理解
Code
#include<iostream>
#include<cstdio>
#include<fstream>
#include<algorithm>
#include<cmath>
#define F(i, x, y) for(int i = x; i <= y; ++ i)
using namespace std;
int read();
const int N = 150000;
int n, k, ans;
int x, y, z;
int s[N];
int search(int x)
{
	int n = x, tmp;
	while(x != s[x]) x = s[x];
	while(n != x) tmp = s[n], s[n] = x, n = tmp;
	return x;
}
int main()
{
	n = read(), k = read();
	F(i, 1, 3 * n) s[i] = i;
	while(k --)
	{
		z = read(), x = read(), y = read();
		if((x == y && z == 2) || x > n || y > n) {++ ans; continue;}
		if(z == 1)
		{
			if(search(x) == search(y + n) || search(x) == search(y + 2 * n)) {++ ans; continue;}
			if(search(x) != search(y))
				s[search(x)] = search(y), s[search(x + n)] = search(y + n), s[search(x + 2 * n)] = search(y + 2 * n);
		}
		if(z == 2)
		{
			if(search(x) == search(y + 2 * n) || search(x) == search(y)) {++ ans; continue;}
			if(search(x) != search(y + n))
				s[search(x)] = search(y + n), s[search(x + n)] = search(y + 2 * n), s[search(x +2 * n)] = search(y);
		}
	}
	printf("%d", ans);
	return 0;
}
int read()
{
	int x = 0;
	char c = getchar();
	while(c < '0' || c > '9') c = getchar();
	while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
	return x;
}
【题解】P2024 [NOI2001]食物链 - 数据结构 - 并查集的更多相关文章
- P2024 [NOI2001]食物链(种类并查集)
		题目链接: https://www.luogu.org/problemnew/show/P2024 题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 ... 
- 洛谷 P2024 [NOI2001]食物链 (并查集)
		嗯... 题目链接:https://www.luogu.org/problemnew/show/P2024 这道题和团伙这道题的思想比较类似,都是一个数组分成几个集合,但这道题的思路更加混乱,建议没做 ... 
- P2024 [NOI2001]食物链[扩展域并查集]
		大水题一道啊,几分钟切掉. 还是扩展域,每个点拆3个点,之间连边表示有关系(即捕食关系).然后随便判定一下就好了,不难,毕竟NOI上古题目. #include<iostream> #inc ... 
- [NOI2001] 食物链 (扩展域并查集)
		题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个动物都是 A,B,C 中的一种,但是我 ... 
- [NOI2001]食物链(并查集拓展域)&&  [HAOI2006]旅行(Kruskal)
		题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个动物都是 A,B,C 中的一种,但是我 ... 
- 洛谷 P2024 [NOI2001]食物链 解题报告
		P2024 [NOI2001]食物链 题目描述 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A 吃 B,B 吃 C,C 吃 A. 现有 N 个动物,以 1 - N 编号.每个 ... 
- 洛谷 P2024 [NOI2001]食物链
		题意简述 有人用两种说法对这 N 个动物所构成的食物链关系进行描述: 1."1 X Y",表示 X 和 Y 是同类. 2."2 X Y",表示 X 吃 Y . ... 
- 算法手记 之 数据结构(并查集详解)(POJ1703)
		<ACM/ICPC算法训练教程>读书笔记-这一次补上并查集的部分.将对并查集的思想进行详细阐述,并附上本人AC掉POJ1703的Code. 在一些有N个元素的集合应用问题中,通常会将每个元 ... 
- ACM数据结构-并查集
		ACM数据结构-并查集 并查集,在一些有N个元素的集合应用问题中,我们通常是在开始时让每个元素构成一个单元素的集合,然后按一定顺序将属于同一组的元素所在的集合合并,其间要反复查找一个元素在哪个集合 ... 
随机推荐
- JSOI 2016 病毒感染 辅助Dp问题
			原题链接:https://www.luogu.com.cn/problem/P5774 分析 直接看这道题,第一个困惑点,那个绝对值的比较是什么东西,根据数学知识,我们可以知道这个意思是k到i的距离小 ... 
- 用Arcgis缓存文件发布服务
			切片文件类型为: 其中_alllayers中为各等级的切片文件,xml文件为切片信息(级别).发布服务的步骤如下: 1.将文件拷贝到服务器上: 2.将gdb和xml文件拷贝出来,放到桌面上: 3.打开 ... 
- 大O 表示法
			大O表示法 指出了算法有多快.例如,假设列表包含n个元素.简单查找需要检查每个元素,因此需要执行n次操作.使用大O表示法,这个运行时间为O(n).单位秒呢?没有——大O表示法指的并非以秒为单位的速度. ... 
- 【动态规划】最佳加法表达式(百练oj4152)
			总时间限制: 1000ms 内存限制: 65536kB 描述 给定n个1到9的数字,要求在数字之间摆放m个加号(加号两边必须有数字),使得所得到的加法表达式的值最小,并输出该值.例如,在1234中摆放 ... 
- Git 命令实战入门 ,奶妈级教程
			我不会用*官方*的语言告诉你Git 是什么,对此我表示深深得歉意--在我看来像CSDN.博客园.掘金等博客交流平台就是小的“GitHub”,只不过在这里更多的是一些零零散散的笔记或者文章,其实Gihu ... 
- 快速创建Flask Restful API项目
			前言 Python必学的两大web框架之一Flask,俗称微框架.它只需要一个文件,几行代码就可以完成一个简单的http请求服务. 但是我们需要用flask来提供中型甚至大型web restful a ... 
- coderforces Gym 100803A/Aizu 1345/CSU 1536/UVALive 6832 Bit String Reordering(贪心证明缺)
			Portal: http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=1345 http://codeforces.com/gym/100 ... 
- 2.Metasploit数据库配置及扫描模块介绍
			01.Metasploit数据库配置及扫描模块介绍 信息收集 信息收集是渗透测试中首先要做的重要事项之一,目的是尽可能多的查找关于目标的信息,我们掌握的信息越多,渗透成功的机会越大.在信息 ... 
- CCF2018 12 2题,小明终于到家了
			最近在愁着备考,拿CCF刷题,就遇到这个难题,最后搜索了一下大佬们的方法,终于解决, 问题描述 一次放学的时候,小明已经规划好了自己回家的路线,并且能够预测经过各个路段的时间.同时,小明通过学校里安装 ... 
- 3-1. 基于epoll架构的视频采集端设计
			精通epoll架构 epoll:Linux中最优秀的多路复用机制! 与select .poll区别 1.select和poll没有太大区别,除了select有文件描述符限制(1024个).select ... 
