题目描述 Description

动物王国中有三类动物 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),输出假话的总数。

输入描述 Input Description

第一行是两个整数N和K,以一个空格分隔。   

以下K行每行是三个正整数D,X,Y,两数之间用一个空格隔开,其中 D 表示说法的种类。   

若D=1,则表示X和Y是同类。   

若D=2,则表示X吃Y。

输出描述 Output Description

只有一个整数,表示假话的数目。

样例输入 Sample Input

100 7

1 101 1

2 1 2

2 2 3

2 3 3

1 1 3

2 3 1

1 5 5

样例输出 Sample Output

3

/*
当前节点与父亲结点的关系:
0 代表与父亲结点同类
1 代表被父亲结点吃
2 代表吃父亲结点
我们开一个数组re[i],记录i号动物的种类情况。
种类有三种,分别记为0,1,2,1吃0,2吃1,0吃2。
对于每一个并查集,我们取根节点的类型为0.
*/
#include<cstdio>
#include<iostream>
#define M 50010
using namespace std;
int re[M],fa[M],n,m;
int find(int x)
{
if(x==fa[x])return x;
int t=fa[x];
fa[x]=find(fa[x]);
re[x]=(re[x]+re[t])%;//利用x的直接父亲t来更新x
return fa[x];
}
/*建立关系时,先将两个子树的树根建立关系,之后两个数根与其子结点的关系在find函数中更新*/
void build(int x,int y,int r)
{
int a=find(x),b=find(y);
fa[a]=b;
re[a]=(re[y]-re[x]+r+)%;
}
int main()
{
scanf("%d%d",&n,&m);
int ans=;
for(int i=;i<=n;i++)fa[i]=i;
for(int i=;i<=m;i++)
{
int f,x,y;
scanf("%d%d%d",&f,&x,&y);
if(x>n||y>n)
{
ans++;
continue;
}
if(f==)//同类
{
if(find(x)!=find(y))build(x,y,);
else if(re[x]!=re[y])ans++;
}
else//x吃y,所以re[x]比re[y]大1
{
if(find(x)!=find(y))build(x,y,);
else if(re[x]!=(re[y]+)%)ans++;
}
}
printf("%d",ans);
return ;
}

最新文章

  1. Python学习——基础篇
  2. du -sh
  3. scala函数式编程
  4. [SC] OpenSCManager FAILED 1722
  5. 手机游戏产品经理(一)logo的印象非常重要,以促进
  6. java fork-join框架应用和分析
  7. 使用 dotnet core 和 Azure PaaS服务进行devOps开发(Web API 实例)
  8. VS2017 性能优化方法
  9. 【CQOI2017】【BZOJ4813】小Q的棋盘 DFS
  10. centos病毒
  11. [转]Understand QoS at OpenSwitch
  12. HTTP协议【详解】——经典面试题
  13. BZOJ 4804: 欧拉心算
  14. sringboot项目在tomcat上的部署
  15. 64位Windows的Dos中取消了edit命令
  16. Gunicorn部署部分的翻译
  17. 在Hadoop1.2.1上运行第一个Hadoop程序FileSystemCat
  18. 【ZOJ3899】State Reversing 解题报告
  19. CLH队列锁
  20. [转]JavaScript RegExp 对象参考手册

热门文章

  1. POJ2437 Muddy roads
  2. maven加载spring包
  3. groovy-闭包
  4. POJ 3273 Monthly Expense
  5. form的submit与onsubmit的用法与区别
  6. ExtJS入门教程01,Window如此简单,你怎能不会?
  7. Yii查看执行的SQL
  8. win7电脑安装wamp出现httpd.exe无法找到组件MSVCR100.dll的解决办法
  9. ExtJS学习之路第二步:Ext.Component 和 Ext.dom.Element 的区别
  10. Win10走红背后,最开心的人却是谷歌