#bINGCHAJIlydlt40x4103. 食物链

食物链

题目描述

动物王国中有三类动物 A,B,C,这三类动物的食物链构成了有趣的环形。

A 吃 B,B 吃 C,C 吃 A。

现有 NN 个动物,以 1N1 \sim N 编号。

每个动物都是 A,B,C 中的一种,但是我们并不知道它到底是哪一种。

有人用两种说法对这 NN 个动物所构成的食物链关系进行描述:

第一种说法是 1 X Y,表示 XXYY 是同类。

第二种说法是 2 X Y,表示 XXYY

此人对 NN 个动物,用上述两种说法,一句接一句地说出 KK 句话,这 KK 句话有的是真的,有的是假的。

当一句话满足下列三条之一时,这句话就是假话,否则就是真话。

  1. 当前的话与前面的某些真的话冲突,就是假话;
  2. 当前的话中 XXYYNN 大,就是假话;
  3. 当前的话表示 XXXX,就是假话。

你的任务是根据给定的 NNKK 句话,输出假话的总数。

输入格式

第一行是两个整数 NNKK,以一个空格分隔。

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

D=1D=1,则表示 XXYY 是同类。

D=2D=2,则表示 XXYY

输出格式

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

样例

输入样例:

100 7
1 101 1 
2 1 2
2 2 3 
2 3 3 
1 1 3 
2 3 1 
1 5 5

输出样例:

3

样例解释

N=100,K=7N=100, K=7

  1. 1 101 1X=101>N=100X=101 > N=100,假话(条件 2),假话数=1
  2. 2 1 2:真话,记录“1 吃 2”
  3. 2 2 3:真话,记录“2 吃 3”,推出“1 吃 3”(传递性)
  4. 2 3 3XXXX,假话(条件 3),假话数=2
  5. 1 1 3:前面已推得“1 吃 3”,与“1 和 3 同类”冲突,假话(条件 1),假话数=3
  6. 2 3 1:根据环形“C 吃 A”和已得关系,可判断真假,此处为真
  7. 1 5 5:同类且 X,YNX,Y \le N,真话

总假话数 = 3。

数据范围

  • 1N500001 \le N \le 50000
  • 0K1000000 \le K \le 100000

时空限制

  • 时间限制:1 秒
  • 空间限制:64 MB