食物链(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吃 ...
随机推荐
- python基础实战
字符串的互相转换 字典的排序 字典的排序可以直接把,key值或者,values拿出来排序 也可以用dict.items拿出所有的key,value的值再加key=lambda x:x[1] 来排序. ...
- 使用Mybatis出现的问题+配置优化+ResultMap
一.可能出现的问题 1.Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: ...
- 记一次 .NET 某化妆品 webapi 卡死分析
一:背景 1. 讲故事 10月份星球里的一位老朋友找到我,说他们公司的程序在一个网红直播带货下给弄得无响应了,无响应期间有大量的 RabbitMQ 超时,寻求如何找到根源,聊天截图我就不发了. 既然无 ...
- 业务逻辑审批流、审批流、业务、逻辑、面向对象、工作方式【c#】
------需求分析:--------1.先按照实际线下流程说这是什么事情,实际要干什么.2.再转换为面向对象-页面的操作流程,演示demo3.再与相关人员沟通是否可行需要什么地方修正.4.最终:线上 ...
- 学习java的第二十六天
一.今日收获 1.java完全学习手册第三章算法的3.2排序,比较了跟c语言排序上的不同 2.观看哔哩哔哩上的教学视频 二.今日问题 1.快速排序法的运行调试多次 2.哔哩哔哩教学视频的一些术语不太理 ...
- .Net 下高性能分表分库组件-连接模式原理
ShardingCore ShardingCore 一款ef-core下高性能.轻量级针对分表分库读写分离的解决方案,具有零依赖.零学习成本.零业务代码入侵. Github Source Code 助 ...
- NuxtJS的AsyncData和Fetch使用详解
asyncData 简介 asyncData 可以用来在客户端加载 Data 数据之前对其做一些处理,也可以在此发起异步请求,提前设置数据,这样在客户端加载页面的时候,就会直接加载提前渲染好并带有数据 ...
- RestTemplate的exchange()方法,解决put和delete请求拿不到返回值的问题
嗷嗷待哺的controller(被调用provider的controller方法) //测试get少量参数 @RequestMapping(value = "detailsGetD" ...
- hash 模式与 history 模式小记
hash 模式 这里的 hash 就是指 url 后的 # 号以及后面的字符.比如说 "www.baidu.com/#hashhash" ,其中 "#hashhash&q ...
- 【Spring Framework】Spring入门教程(三)使用注解配置
本文主要介绍四个方面: (1) 注解版本IOC和DI (2) Spring纯注解 (3) Spring测试 (4) SpringJDBC - Spring对数据库的操作 使用注解配置Spring入门 ...