食物链(poj1182)
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 57387 | Accepted: 16781 |
Description
现有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
以下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)的更多相关文章
- ACM/ICPC 之 并查集-食物链(POJ1182)
并查集的经典题型,POJ上题目还是中文= =,一般看到中文题都会感觉不太简单,这道题的数学归纳用得比较多,可以简化代码,挺有意思的. 同类型的题目还有POJ1703,比这个要简单,想了解并查集基本介绍 ...
- 食物链--poj1182(并查集含有关系)
http://poj.org/problem?id=1182 题意应该就不用说了 再次回到食物链这道题,自己写了一遍,一直wa...原因竟然是不能用多实例,我也是醉了,但是我真的彻底的理解了,那 ...
- E - 食物链 poj1182
题目告诉有 3 种动物,互相吃与被吃,现在告诉你 m 句话,其中有真有假,叫你判断假的个数 ( 如果前面没有与当前话冲突的,即认为其为真话 ).每句话开始都有三个数 D A B,当D = ...
- (并查集 建立关系)食物链 -- POJ-- 1182
链接: http://poj.org/problem?id=1182 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=82830#probl ...
- POJ-1182(经典带权并查集)
食物链 POJ-1182 一个很好的分析博客:https://blog.csdn.net/niushuai666/article/details/6981689 三种关系:两者同类,吃父节点,被父节点 ...
- NOI2001|POJ1182食物链[种类并查集 向量]
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 65430 Accepted: 19283 Description ...
- 并查集专辑 (poj1182食物链,hdu3038, poj1733, poj1984, zoj3261)
并查集专题训练地址,注册登录了才能看到题目 并查集是一个树形的数据结构, 可以用来处理集合的问题, 也可以用来维护动态连通性,或者元素之间关系的传递(关系必须具有传递性才能有并查集来维护,因为并查集 ...
- POJ1182 食物链---(经典种类并查集)
题目链接:http://poj.org/problem?id=1182 食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submission ...
- POJ-1182 食物链 并查集(互相关联的并查集写法)
题目链接:https://cn.vjudge.net/problem/POJ-1182 题意 中文题目,就不写了哈哈 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃 ...
随机推荐
- 11 — springboot集成swagger — 更新完毕
1.前言 理论知识滤过,自行百度百科swagger是什么 2.导入依赖 <!-- swagger所需要的依赖--> <dependency> <groupId>io ...
- C++自定义字符串类
//header.h #ifndef _HEADER_H #define _HEADER_H #define defaultSize 128 #include<iostream> #inc ...
- 节省内存的循环banner(一)
循环banner是指scrollview首尾相连,循环播放的效果,使用非常广泛.例如淘宝的广告栏等. 如果是简单的做法可以把所有要显示的图片全部放进一个数组里,创建相同个数的图片视图来显示图片.这样的 ...
- ORACLE CACHE BUFFER CHAINS原理
原理图如下: 一个cache buffer chains 管理多个hash bucket,受隐含参数:_db_block_hash_buckets(控制管理几个hash bucket)
- 【JavaWeb】【Eclipse】使用Eclipse创建我的第一个网页
使用Eclipse创建我的第一个网页 哔哩哔哩 萌狼蓝天 你可以直接点击Finish,也可以点击Next,到下面这个界面后,勾选生成web.xml然后Finish(你不这样做就会没有Web.xml文件 ...
- hibernate多对多单向(双向)关系映射
n-n(多对多)的关联关系必须通过连接表实现.下面以商品种类和商品之间的关系,即一个商品种类下面可以有多种商品,一种商品又可以属于多个商品种类,分别介绍单向的n-n关联关系和双向的n-n关联关系. 单 ...
- Python绘制饼图
Python绘制饼图 1.1 对应代码如下图所示 import matplotlib.pyplot as pltfrom pylab import mplmpl.rcParams['font.sans ...
- MySQL如何把varchar类型字段转换成int类型进行倒叙排序
SELECT * FROM sheet2 t1 WHERE t1.`金额`+'0' ORDER BY t1.`金额` DESC;
- Game On Serverless:SAE 助力广州小迈提升微服务研发效能
作者:洛浩 小迈于 2015 年 1 月成立,是一家致力以数字化领先为优势,实现业务高质量自增长的移动互联网科技公司.始终坚持以用户价值为中心,以数据为驱动,为用户开发丰富的工具应用.休闲游戏.益智. ...
- Hive实战UDF 外部依赖文件找不到的问题
目录 关于外部依赖文件找不到的问题 为什么要使用外部依赖 为什么idea 里面可以运行上线之后不行 依赖文件直接打包在jar 包里面不香吗 学会独立思考并且解决问题 继承DbSearcher 读取文件 ...