食物链
Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 57387   Accepted: 16781

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

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
思路:并查集.详解翻阅挑战程序设计竞赛(第二版p89)
粗略的说下思路,每个动物有三种状态,分别用数字表示是i,i+p,i+2p;
如果i,j为同一种,则有i,j在同一集合,i+p与j+p同一集合,i+2p,j+2p 同一集合,
如果i吃j,就有i,j+p同一集合,i+p,j+2p同一集合,i+2p,j同一集合。
这样如果j,吃z,根据这样合并,就可以得到z,吃i;
那么每个询问判下是否矛盾就可以了。
  1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<stdlib.h>
5 #include<string.h>
6 const int N=5*30005;
7 using namespace std;
8 int dian[3*N];
9 int quan[3*N];
10 int main(void)
11 {
12 int i,j,k,p,q;
13 int x1,x2,x3;
14 scanf("%d %d",&p,&q);
15 {
16 for(i=0; i<3*N; i++)
17 {
18 quan[i]=1;
19 dian[i]=i;
20 }
21 int cnt=0;
22 while(q--)
23 {
24 scanf("%d %d %d",&x1,&x2,&x3);
25 int xx1,yy1;
26 int xx2,yy2;
27 int xx3,yy3;
28 for(xx1=x2;dian[xx1]!=xx1;)
29 xx1=dian[xx1];
30 for(yy1=x3;dian[yy1]!=yy1;)
31 yy1=dian[yy1];
32 for(xx2=x2+p;xx2!=dian[xx2];)
33 xx2=dian[xx2];
34 for(yy2=x3+p;yy2!=dian[yy2];)
35 yy2=dian[yy2];
36 for(xx3=x2+2*p;xx3!=dian[xx3];)
37 xx3=dian[xx3];
38 for(yy3=x3+2*p;yy3!=dian[yy3];)
39 yy3=dian[yy3];
40 if(x2<=0||x3<=0||x2>p||x3>p)
41 {
42 cnt++;
43 }
44 else
45 {if(x1==1)
46 {
47 if(xx1!=yy1&&xx1!=yy2&&yy1!=xx2)
48 {
49 if(quan[xx1]>=quan[yy1])
50 {
51 quan[xx1]+=quan[yy1];
52 dian[yy1]=xx1;
53 quan[xx2]+=quan[yy2];
54 dian[yy2]=xx2;
55 quan[xx3]+=quan[yy3];
56 dian[yy3]=xx3;
57 }
58 else
59 {
60 quan[yy1]+=quan[xx1];
61 dian[xx1]=yy1;
62 quan[yy2]+=quan[xx2];
63 dian[xx2]=yy2;
64 quan[yy3]+=quan[xx3];
65 dian[xx3]=yy3;
66 }
67 }
68 else if(xx1==yy1){continue;}
69 else cnt++;
70 }
71 if(x1==2)
72 {
73 if(xx1!=yy1&&xx1!=yy2&&yy1!=xx2)
74 {
75 if(quan[xx1]>=quan[yy2])
76 {
77 quan[xx1]+=quan[yy2];
78 dian[yy2]=xx1;
79 quan[xx2]+=quan[yy3];
80 dian[yy3]=xx2;
81 quan[xx3]+=quan[yy1];
82 dian[yy1]=xx3;
83 }
84 else
85 {
86 quan[yy2]+=quan[xx1];
87 dian[xx1]=yy2;
88 quan[yy3]+=quan[xx2];
89 dian[xx2]=yy3;
90 quan[yy1]+=quan[xx3];
91 dian[xx3]=yy1;
92 }
93 }
94 else if(xx1==yy2)
95 {
96 continue;
97 }
98 else cnt++;
99 }
100
101 }}printf("%d\n",cnt);
102
103 } return 0;}

食物链(poj1182)的更多相关文章

  1. ACM/ICPC 之 并查集-食物链(POJ1182)

    并查集的经典题型,POJ上题目还是中文= =,一般看到中文题都会感觉不太简单,这道题的数学归纳用得比较多,可以简化代码,挺有意思的. 同类型的题目还有POJ1703,比这个要简单,想了解并查集基本介绍 ...

  2. 食物链--poj1182(并查集含有关系)

    http://poj.org/problem?id=1182   题意应该就不用说了  再次回到食物链这道题,自己写了一遍,一直wa...原因竟然是不能用多实例,我也是醉了,但是我真的彻底的理解了,那 ...

  3. E - 食物链 poj1182

    题目告诉有  3  种动物,互相吃与被吃,现在告诉你  m  句话,其中有真有假,叫你判断假的个数  (  如果前面没有与当前话冲突的,即认为其为真话  ).每句话开始都有三个数 D A B,当D = ...

  4. (并查集 建立关系)食物链 -- POJ-- 1182

    链接: http://poj.org/problem?id=1182 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=82830#probl ...

  5. POJ-1182(经典带权并查集)

    食物链 POJ-1182 一个很好的分析博客:https://blog.csdn.net/niushuai666/article/details/6981689 三种关系:两者同类,吃父节点,被父节点 ...

  6. NOI2001|POJ1182食物链[种类并查集 向量]

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

  7. 并查集专辑 (poj1182食物链,hdu3038, poj1733, poj1984, zoj3261)

    并查集专题训练地址,注册登录了才能看到题目 并查集是一个树形的数据结构,  可以用来处理集合的问题, 也可以用来维护动态连通性,或者元素之间关系的传递(关系必须具有传递性才能有并查集来维护,因为并查集 ...

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

    题目链接:http://poj.org/problem?id=1182   食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submission ...

  9. POJ-1182 食物链 并查集(互相关联的并查集写法)

    题目链接:https://cn.vjudge.net/problem/POJ-1182 题意 中文题目,就不写了哈哈 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃 ...

随机推荐

  1. 单元测试在Unity中的应用

    项目描述:简单演示单元测试在Unity中的应用 项目地址:UnityTestRunner_Tutorial - SouthBegonia 项目版本:2020.3.20f1 项目用法:打开就用,代码都放 ...

  2. Shell 统计文件的行数

    目录 统计文件的行数 题目 题解-awk 题解-wc 题解sed 统计文件的行数 题目 写一个 bash脚本以输出一个文本文件 nowcoder.txt中的行数 示例: 假设 nowcoder.txt ...

  3. [php反序列化] CVE-2020-15148(Yii2 反序列化漏洞) 漏洞复现

    漏洞影响范围 Yii2 < 2.0.38 环境搭建 Yii2.0.37 漏洞分析 首先定位到漏洞起始点 为什么是这儿?我们该怎么发现是某个类的某个函数?为什么不是其他函数? 一般是__destr ...

  4. 【Reverse】每日必逆0x01

    附件:https://files.buuoj.cn/files/7458c5c0ce999ac491df13cf7a7ed9f1/SimpleRev 题解 查壳 64位ELF文件,无壳 IDApro处 ...

  5. TCP中的TIME_WAIT状态

    TIME_WAIT的存在有两大理由 1.可靠地实现TCP全双工连接的终止 2.允许老的可重复分节在网络中消失. 对于理由1,我们知道TCP结束需要四次挥手,若最后一次的客户端的挥手ACK丢失(假设是客 ...

  6. Stream collect Collectors 常用详细实例

    返回List集合: toList() 用于将元素累积到List集合中.它将创建一个新List集合(不会更改当前集合). List<Integer> integers = Arrays.as ...

  7. @Data 注解引出的 lombok

    今天在看代码的时候, 看到了这个注解, 之前都没有见过, 所以就查了下, 发现还是个不错的注解, 可以让代码更加简洁. 这个注解来自于 lombok,lombok 能够减少大量的模板代码,减少了在使用 ...

  8. Linux基础命令---vmstat显示虚拟内存状态

    vmstat vmstat指令用来显示虚拟内存使用状态,同时也可以显示进程.cpu活动情况.vmstat报告有关进程.内存.分页.块IO.陷阱和CPU活动的信息.生成的第一份报告给出了自上次重新启动以 ...

  9. redis入门到精通系列(五):redis的持久化操作(RDB、AOF)

    (一)持久化的概述 持久化顾名思义就是将存储在内存的数据转存到硬盘中.在生活中使用word等应用的时候,如果突然遇到断电的情况,理论上数据应该是都不见的,因为没有保存的word内容都存放在内存里,断电 ...

  10. Dubbo管控平台

    2019年初,官方发布了Dubbo管理控制台0.1版本.结构上采取了前后端分离的方式,前端使用Vue和Vuetify分别作为Javascript框架和UI框架,后端采用Spring Boot框架 一. ...