食物链

题目描述

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

输入输出格式

输入格式:

从 eat.in 中输入数据

第一行两个整数,N,K,表示有 N 个动物,K 句话。

第二行开始每行一句话(按照题目要求,见样例)

输出格式:

输出到 eat.out 中

一行,一个整数,表示假话的总数。

输入输出样例

输入样例#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

说明

1 ≤ N ≤ 5 ∗ 10^4

1 ≤ K ≤ 10^5

/*
对每个对象有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<bits/stdc++.h>
using namespace std;
#define N 50010
int n,k,fa[N*3];
int find(int u)
{
    return fa[u]==u?fa[u]:fa[u]=find(fa[u]);
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cin>>n>>k;
    int d,x,y,fx1,fx2,fx3,fy1,fy2,fy3,tot=0;
    for(int i=1; i<=n*3; i++)fa[i]=i;
    for(int i=1; i<=k; i++)
    {
        cin>>d>>x>>y;
        if(x<1||x>n||y<1||y>n)
        {
            tot++;
            continue;
        }
        if(d==2&&x==y)
        {
            tot++;
            continue;
        }
        fx1 = find(x);fx2 = find(x+n);fx3 = find(x+2*n);
        fy1 = find(y);fy2 = find(y+n);fy3 = find(y+2*n);
        if(d==1)
        {
            if(fx1==fy2||fx1==fy3)
            {
                tot++;
                continue;
            }
            else fa[fx1]=fy1,fa[fx2]=fy2,fa[fx3]=fy3;
        }
        else
        {
            if(fx1==fy1||fx1==fy3)
            {
                tot++;
                continue;
            }
            else fa[fx1]=fy2,fa[fx2]=fy3,fa[fx3]=fy1;
        }
    }
    cout<<tot;
    return 0;
}

心若向阳,无谓悲伤

时间: 2024-12-19 03:14:23

食物链的相关文章

poj 1182 食物链

食物链 题意:"1 X Y",表示X和Y是同类;"2 X Y",表示X吃Y;输入N(1 <= N <= 50,000),(0 <= K <= 100,000)表示最多有N个动物,同时有K句话. 如果当前的话与前面的话不矛盾就说当前的话是正确的:(无罪判定)问这K句话中有几句是假话: 思路:很裸的种类并查集,只是里面穿插了三种关系,即同类,A吃B,B吃A:其实看了数组的范围[3*N]和x+N,x+2*N就知道思路了:即x吃x+N;类推 对于判定

NOI 2001 &amp; luogu P2024 &amp; POJ 1182食物链

食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 71707   Accepted: 21240 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种. 有人用两种说法对这N个动物所构成的食物链关系进行描述: 第一种说法是"1 X Y",表示X和Y是同

POJ1182 食物链---(经典种类并查集)

题目链接:http://poj.org/problem?id=1182 食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 69207   Accepted: 20462 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种. 有人用两种说法对这N个动物所构成的食

【POJ1182】 食物链 (带权并查集)

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句话有的是真的,有的是假的.当一句话满足下列三条之

tyvj1202 数数食物链

描述 TsyD学习了生物的生态环境那一张后,老师留了一项作业,就是给一张食物网,求所有食物链的总数.(从最低营养级生物(它不能吃任何其他的生物)开始到最高营养级(它不能被任何其他生物吃) 叫做一条食物链)输入保证所有的生物之间都有直接或间接的生存关系 输入格式 第一行 N,M 分别表示有N(N<=50000)个生物,M(M<=100000)个吃的关系接下来M行 每行有两个值a,b 分别 表示b吃a (编号从1开始) 输出格式 食物链的总数 MOD 11129 的值 测试样例1 输入 3 3 1

【NOI2001】食物链

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句话有的是真的,有的是假的.当一句话满足下列三条之一时,这句话就是假话,否则就是

POJ 1182 :食物链(并查集)

食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 43526   Accepted: 12679 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号. 每一个动物都是A,B,C中的一种,可是我们并不知道它究竟是哪一种. 有人用两种说法对这N个动物所构成的食物链关系进行描写叙述: 第一种说法是"1 X Y",表示X

poj 2912 并查集(食物链加强版)

题目:给出n个人玩剪刀石头布的游戏,其中有一个人是裁判,剩下的人分为3组,每一组的人只出某一种手型,裁判可以任意出.问是否能判断出哪个人是裁判 链接:点我 分分钟看吐血,先把食物链看懂吧 枚举裁判,然后并查集判断 裁判由于可以任意出,所以可能属于任意一个集合,所以有裁判参与的会合不考虑,然后并查集部分和食物链很相似. 如果某个裁判那里出现了矛盾,则记录一下在哪出问题. 然后判断是否只有一个裁判没有出现问题.如果只有一个,说明可以确定,那么就是剩下的人出问题的最大值.因为只有否定了其它所有人,才能

POJ 1182(食物链-另类做法【拆点】)[template:并查集]

食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 46039   Accepted: 13400 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种. 有人用两种说法对这N个动物所构成的食物链关系进行描述: 第一种说法是"1 X Y",表示X和Y是同