1074 食物链 2001年NOI全国竞赛
1074 食物链
2001年NOI全国竞赛
动物王国中有三类动物 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句话有的是真的,有的是假的。当一句话满足下列三条之一时,这句话就是假话,否则就是真话。
1) 当前的话与前面的某些真的话冲突,就是假话;
2) 当前的话中X或Y比N大,就是假话;
3) 当前的话表示X吃X,就是假话。
你的任务是根据给定的N(1<=N<=50,000)和K句话(0<=K<=100,000),输出假话的总数。
第一行是两个整数N和K,以一个空格分隔。
以下K行每行是三个正整数D,X,Y,两数之间用一个空格隔开,其中 D 表示说法的种类。
若D=1,则表示X和Y是同类。
若D=2,则表示X吃Y。
只有一个整数,表示假话的数目。
100 7
1 101 1
2 1 2
2 2 3
2 3 3
1 1 3
2 3 1
1 5 5
3
输入文件
对7句话的分析 100 7
1 101 1 假话
2 1 2 真话
2 2 3 真话
2 3 3 假话
1 1 3 假话
2 3 1 真话
1 5 5 真话
NOI 2001 食物链(eat)
数组一定要开的足够大
对每个对象有3种状态。我们可以开3倍的数组,分别维护对象的三种状态。(因为我们无法确定该对象是A/B/C中的哪种)。
fa[i]、fa[i+n]、 fa[i+2n]
如果对象X,Y是同类。
则我们将3个状态分别连边。
fa[x] <-> fa[y]
fa[x+n]<->fa[y+n]
fa[x+2*n]<->fa[y+2*n]
如果X、Y不是同类存在捕食关系。(设X eat Y)
则我们将
fa[x] <-> fa[y+n] (A->B)
fa[x+n] <-> fa[y+2*n] (B->C)
至于什么要连
fa[x+2*n] <-> fa[y] (C->A)
(其实不连好像也可以,但是我写不出来)
我们需要描述3种关系。
- 同类关系。
- 捕食关系
- 被捕食关系
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int MAXN=;
const int maxn=0x7fffffff;
int tot=;
int f[MAXN];// 同伙
int x,y;
int fx1,fx2,fx3,fy1,fy2,fy3;
int find(int x)
{
if(f[x]!=x)
f[x]=find(f[x]);
return f[x];
}
int unionn(int x,int y)
{
f[x]=y;
}
int main()
{
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=n*;i++)
f[i]=i;
for(int i=;i<=m;i++)
{
int p;
scanf("%d",&p);
if(p==)// x y 是同类
{
int x,y;
scanf("%d%d",&x,&y);
if((x>n||y>n))
{
tot++;
continue;
}
fx1=find(x);
fx2=find(x+n);
fx3=find(x+*n);
fy1=find(y);
fy2=find(y+n);
fy3=find(y+*n);
if(fx1==fy2||fx1==fy3)
{
tot++;
continue;
}
else
{
unionn(fx1,fy1);
unionn(fx2,fy2);
unionn(fx3,fy3);
}
}
else // x吃y
{
scanf("%d%d",&x,&y);
if((x>n||y>n)||(x==y))
{
tot++;
continue;
}
fx1=find(x);
fx2=find(x+n);
fx3=find(x+*n);
fy1=find(y);
fy2=find(y+n);
fy3=find(y+*n);
if(fx1==fy1||fx1==fy3)
{
tot++;
continue;
}
else
{
unionn(fx1,fy2);
unionn(fx2,fy3);
unionn(fx3,fy1);
}
}
}
printf("%d",tot);
return ;
}
1074 食物链 2001年NOI全国竞赛的更多相关文章
- Codevs 1074 食物链 2001年NOI全国竞赛
1074 食物链 2001年NOI全国竞赛 时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description 动物王国中有三类动物 A,B ...
- CODEVS 1074 食物链 2001年NOI全国竞赛(洛谷 P2024)
题目描述 Description 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A吃B,B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并 ...
- 食物链 2001年NOI全国竞赛
时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond 题目描述 Description 动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形.A吃B ...
- Codevs 1800 假面舞会 2008年NOI全国竞赛
1800 假面舞会 2008年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 一年一度的假面舞会又开始了,栋栋也 ...
- 1729 单词查找树 2000年NOI全国竞赛
1729 单词查找树 2000年NOI全国竞赛 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 在进行文法分析的 ...
- 2008年NOI全国竞赛 假面舞会
/* 分三种情况 1 有环:找环长的gcd作为max gcd的超过2的最小因子作为min 2 树:所有最长链的和作为max 3为min (最长链≥3) 3 两条相交链:找出所有的这样的两条链的差 同1 ...
- 1722 最优乘车 1997年NOI全国竞赛
题目描述 Description H城是一个旅游胜地,每年都有成千上万的人前来观光.为方便游客,巴士公司在各个旅游景点及宾馆,饭店等地都设置了巴士站并开通了一些单程巴上线路.每条单程巴士线路从某个巴士 ...
- 银河英雄传说 2002年NOI全国竞赛
时间限制: 1 s 空间限制: 256000 KB 题目等级 : 大师 Master 题目描述 Description 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年 ...
- NOI全国赛(2001)--食物链
今天写了道并查集的题,看来并查集的题刷少了,,,,,用法好神奇啊!!!开三倍并查集 用i表示自己,i+n存天敌,i+2*n存可以克制de,再逻辑判断一下即可. 所以,要意识到并查集的分类处理可以开不同 ...
随机推荐
- JSP编译指令
----------------siwuxie095 编译指令是通知 JSP 引擎的消息,其作用是设置 JSP 程序的属性, 以及由 JSP 生 ...
- 树莓派 Learning 003 --- GPIO 001 --- 点亮LED
树莓派 Learning 003 - GPIO 001 - 点亮LED 我的树莓派型号:Raspberry Pi 2 Model B V1.1 装机系统:NOOBS v1.9.2 树莓派 Learni ...
- 《精通Spring4.X企业应用开发实战》读后感第五章(不同配置方式比较)
- Asp.Net 之 Web.config 配置文件详解 -转
在asp.net中配置文件名一般默认是web.config.每个web.config文件都是基于XML的文本文件,并且可以保存到Web应用程序中的任何目录中.在发布Web应用程序时web.config ...
- Postman使用-1
文章来源:http://www.cnplugins.com/tool/specify-postman-methods.html https://www.cnblogs.com/Skyyj/p/6856 ...
- oracle 导入sql文件乱码
查看 http://blog.csdn.net/fireofjava/article/details/53980966
- Haproxy+Keepalived高可用配置
基本实验 参考文档 博文地址 环境拓扑 下面使我们要实现的负载均衡集群图示 主节点地址: 92.0.0.11 从节点地址: 92.0.0.12 共享虚拟地址:92.0.0.8 下面是负载均衡集群可能出 ...
- VS Code(待补充)
使用! 然后Tab 快速生成html文档结构 快速生成一个类 .类名 会有提示 .container.box .col-6*2 VisualStudio Code怎么同时编辑多处?
- 最大子序列和——HDU-1003 Max Sum
题目大意:给定序列个数n及n个数,求该序列的最大连续子序列的和,要求输出最大连续子序列的和以及子序列的首位位置 解题思路:经典DP,可以定义dp[i]表示以a[i]为结尾的子序列的和的最大值,因而最大 ...
- rgbdslam_v2编译过程中引起的needed by错误
Ubuntu16.04,ROS kinectic 报错信息为“ make[2]: *** No rule to make target '/home/william/slam/g2o/lib/libg ...