食物链(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吃 ...
随机推荐
- 用原生CSS编写动态字体
HTML部分: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ...
- 浅讲.Net 6 之 WebApplicationBuilder
介绍 .Net 6为我们带来的一种全新的引导程序启动的方式.与之前的拆分成Program.cs和Startup不同,整个引导启动代码都在Program.cs中. WebApplicationBuild ...
- 容器之分类与各种测试(三)——slist的用法
slist和forward_list的不同之处在于其所在的库 使用slist需要包含 #include<ext\list> 而使用forward_list则需要包含 #include< ...
- git提交指定文件
1. 用git add 命令添加第一个commit需要的文件 git add file1 git add file2 2. 隐藏其他修改,git stash 的参数中 -k 开关告诉仓库保持文件的完整 ...
- MapStruct对象转换
第一次看到 MapStruct 的时候, 我个人非常的开心.因为其跟我内心里面的想法不谋而合. 1 MapStruct 是什么? 1.1 JavaBean 的困扰 对于代码中 JavaBean之间的转 ...
- JVM——对象已“死”的判定
主要针对Java堆和方法区 1.判断对象是否已"死" Java堆中存放着几乎所有的对象实例,垃圾回收器在对堆进行回收之前,首先应该判断这些对象哪些还"存活",哪 ...
- JAVA序列化浅析
java.io.Serializable浅析 Java API中java.io.Serializable接口源码: 1 public interface Serializable { 2 } 类通过实 ...
- Linux基础命令---ftp
ftp ftp指令可以用来登录远程ftp服务器. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. 1.语法 ftp [ ...
- centos7.4 64位安装 git
参考博客:Linux Jenkins配置Git 1. git --version 查看有没有安装 过 git,没有则 继续 2. git 压缩包下载地址:https://mirrors.edge.ke ...
- 【Java 调优】Java性能优化
Java性能优化的50个细节(珍藏版) 1. 尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间,提高加载的效率,但并不是所有地方都适用于单例,简单来说,单例主要适用于以下三个方面: ...