食物链
Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 50601   Accepted: 14786

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

第一行是两个整数N和K,以一个空格分隔。 
以下K行每行是三个正整数 D,X,Y,两数之间用一个空格隔开,其中D表示说法的种类。 
若D=1,则表示X和Y是同类。 
若D=2,则表示X吃Y。

Output

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

Sample Input

  1. 100 7
  2. 1 101 1
  3. 2 1 2
  4. 2 2 3
  5. 2 3 3
  6. 1 1 3
  7. 2 3 1
  8. 1 5 5

Sample Output

  1. 3
  2.  
  3. 草泥马我终于把这题A了!!!!!!
    当时我看完c primer plus的时候,心中最大的感觉就是真正优秀的教材就是能让傻子都能学懂,依照这样的观念来看———网上的大部分题解写得TM就跟屎一样!!!写不清楚你至少别误人子弟,推个公式推半天结果全是找规律没任何数学证明,乱七八糟写一堆浪费别人时间,要不是找到了那篇思路清晰的不知道还要耗几天!
  4.  
  5. 良心声明:我没精力也没本事把这题讲清楚,下面的过程纯属自用,留着以后自己来看,所以只求我自己能看懂,不建议参考,但是强烈推荐参考这篇: http://blog.csdn.net/niushuai666/article/details/6981689,清晰的说明了网上那堆乱七八糟的公式是如何用数学推出来的!
  6. R[i]的意思是 i的父节点 -> i 的关系,绝对不能反。
  7. STEP 1
  1.  
  1. 这一步要先将x的父节点更新成最上面这个,然后再更新R[x]的值。
  2. STEP 2:

    所以要将右子树挂到左子树上去,那么右子树的根节点的关系值就要更新成它与左子树根节点的关系,从第二个图上可以看出来,新的R[fy] =(R[x] + v + (3 - R[y])) % 3,最后模3是为了确保关系值始终在0-2的范围内。
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <string>
  4. #include <queue>
  5. #include <vector>
  6. #include <map>
  7. #include <algorithm>
  8. #include <cstring>
  9. #include <cctype>
  10. #include <cstdlib>
  11. #include <cmath>
  12. #include <ctime>
  13. using namespace std;
  14.  
  15. const int SIZE = ;
  16. int FATHER[SIZE],R[SIZE];
  17. int N,M,ANS;
  18.  
  19. void ini(void);
  20. int find_father(int);
  21. void unite(int,int,int);
  22. int main(void)
  23. {
  24. int x,y,v;
  25.  
  26. scanf("%d%d",&N,&M);
  27. ini();
  28. while(M --)
  29. {
  30. scanf("%d%d%d",&v,&x,&y);
  31. if(x > N || y > N || (x == y && v == ))
  32. ANS ++;
  33. else
  34. unite(x,y,v);
  35. }
  36. printf("%d\n",ANS);
  37.  
  38. return ;
  39. }
  40.  
  41. void ini(void)
  42. {
  43. ANS = ;
  44. for(int i = ;i <= N;i ++)
  45. {
  46. FATHER[i] = i;
  47. R[i] = ;
  48. }
  49. }
  50.  
  51. int find_father(int n)
  52. {
  53. if(n == FATHER[n])
  54. return n;
  55. int temp = FATHER[n];
  56. FATHER[n] = find_father(FATHER[n]);
  57. R[n] = (R[temp] + R[n]) % ;
  58.  
  59. return FATHER[n];
  60. }
  61.  
  62. void unite(int x,int y,int v)
  63. {
  64. int fx = find_father(x);
  65. int fy = find_father(y);
  66.  
  67. if(fx == fy)
  68. {
  69. if(( - R[x] + R[y]) % != v - )
  70. ANS ++;
  71. return ;
  72. }
  73.  
  74. FATHER[fy] = fx;
  75. R[fy] = (R[x] + v - + - R[y]) % ;
  76. }
  1.  

POJ 1182 食物链 (并查集)的更多相关文章

  1. POJ 1182 食物链 [并查集 带权并查集 开拓思路]

    传送门 P - 食物链 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit  ...

  2. poj 1182 食物链 并查集 题解《挑战程序设计竞赛》

    地址 http://poj.org/problem?id=1182 题解 可以考虑使用并查集解决 但是并不是简单的记录是否同一组的这般使用 每个动物都有三个并查集 自己 天敌 捕食 并查集 那么在获得 ...

  3. POJ 1182 食物链(并查集的使用)

    食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 81915   Accepted: 24462 Description ...

  4. poj 1182 食物链 并查集的又一个用法

    食物链   Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 41584   Accepted: 12090 Descripti ...

  5. POJ 1182食物链(并查集)

    食物链Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 85474 Accepted: 25549Description动物王国中有三 ...

  6. POJ - 1182 食物链 并查集经典

    思路:设r(x)表示节点x与根结点的关系,px表示x的根结点.记录每个节点与其父节点的关系,就能很方便知道每个节点以及和它的父节点的关系. struct node{ int par; //父亲节点 i ...

  7. poj——1182食物链 并查集(提升版)

    因为是中文题,题意就不说了,直接说思路: 我们不知道给的说法中的动物属于A B C哪一类,所以我们可以用不同区间的数字表示这几类动物,这并不影响结果,我们可以用并查集把属于一类的动物放在一块,举个例子 ...

  8. POJ 1182 食物链(并查集)

    题目链接 经过宝哥的讲解,终于对这种问题有了进一步的理解.根据flag[x]和flag[y]求flag[tx]是最关键的了. 0吃1,1吃2,2吃0. 假设flag[tx] = X; 那么X + fl ...

  9. poj 1182 (关系并查集) 食物链

    题目传送门:http://poj.org/problem?id=1182 这是一道关系型并查集的题,对于每个动物来说,只有三种情况:同类,吃与被吃: 所以可以用0,1,2三个数字代表三种情况,在使用并 ...

随机推荐

  1. jedis提供的功能

    Sorting(排序) Connection handling(连接池) Commands operating on any kind of values Commands operating on ...

  2. GIT 中提示 please tell me who you are

    如果使用git过程中出现了,please tell me who you are ,需要设置一下使用者的身份. 1.git config user.name "username" ...

  3. Ext的Panel总结(好文章)

    我刚才禁不住诱惑去看了一下Ext.Window的API文档,发现只是比Panel多了点什么最大化.最小化.关闭.置前.置后.动画引发目标设置.可调整大小这些功能.像什么标题栏.工具栏之类的东西在Ext ...

  4. hdu 2821 Pusher (dfs)

    把这个写出来是不是就意味着把   http://www.hacker.org/push  这个游戏打爆了? ~啊哈哈哈 其实只要找到一个就可以退出了  所以效率也不算很低的  可以直接DFS呀呀呀呀 ...

  5. C++的优秀特性1:引用

    (转载请注明原创于潘多拉盒子) 一本典型的C语言教科书的厚度大约是200页左右,而一本典型的C++教科书的厚度至少要500页.比如K&R的<The C Programming Langu ...

  6. jeecg团队招新人(5人)

    jeecg团队招新人(5人) http://www.jeecg.org/forum.php? mod=viewthread&tid=2046&page=1&extra=#pid ...

  7. rails中的语法

    1. erb文件中的语法说明 erb文件中常混合使用Ruby语言和html语言,以下为两种常见的格式 <% 写逻辑脚本(Ruby语法) %> <%= 直接输出变量值或运算结果 %&g ...

  8. Celery学习笔记

    转载请注明出处:点我 我的第一篇博客!嘿嘿! 在公司实习,接触到的第一个项目就用到了Celery,之前是完全没有接触过Celery这玩意,然后花了点时间仔细的研究了下怎么用.在学习过程中也遇到了些问题 ...

  9. javascript异步延时载入及推断是否已载入js/css文件

    <html> <head> <script type="text/javascript"> /**======================= ...

  10. Php-SPL库中的迭代器类详解(转)

    SPL提供了多个迭代器类,分别提供了迭代访问.过滤数据.缓存结果.控制分页等功能.,因为php总是在不断壮大,我尽可能列出SPL中所有的迭代类.下面其中一些迭代器类是需要php5.4,另外一些如Sea ...