POJ 1182食物链、
应用挑战程序设计那本书上的话:
对于每只动物i创建3个元素i—A,i—B,i—C,并用3xN个元素建立并查集。这个并查集维护如下信息:
(1)i—x表示“i属于种类x”
(2)并查集里的每一个组表示组内所有元素代表的情况都相同都同时发生或不发生
for example,如果i—A和j—B在同一个组里,就表示如果i属于种类A那么j一定属于种类B,如果j属于种类B那么i一定属于种类A。因此,对于每一条信息,只需要按照以下进行操作就可以了。
第一种,x和y属于同一类......合并x—A和y—A,x—B和y—B,x—C和y—C。
第二种,x吃y....................合并x—A和y—B,x—B和y—C,x—C和y—A。
不过在合并之前,需要先判断合并是否产生矛盾。例如在第一种信息的情况下,需要检查比如x—A和y—B或者y—C是否在同一组等信息
#include<cstdio>
#include<cstring>
const int N=50000+10;
int pre[N*3];
void init(int n)
{
for(int i=0;i<=n*3;++i)
pre[i]=i;
}
int find(int x)
{
if(x==pre[x])
return x;
else
return pre[x]=find(pre[x]);
}
bool same(int a,int b)
{
return find(a)==find(b);
}
void un(int a,int b)
{
int x=find(a);
int y=find(b);
if(x==y)
return;
else
pre[x]=y;
}
int main()
{
int n,k;
scanf("%d%d",&n,&k);
int ans=0;
init(n);
for(int i=0;i<k;++i){
int r,x,y;
scanf("%d%d%d",&r,&x,&y);
if(x>n||y>n||x<=0||y<=0){
++ans;
continue;
}
if(r==1){
if(same(x,y+n)||same(x,y+2*n))
++ans;
else{
un(x,y);
un(x+n,y+n);
un(x+2*n,y+2*n);
}
}
else{
if(same(x,y)||same(x,y+2*n))
++ans;
else{
un(x,y+n);
un(x+n,y+2*n);
un(x+2*n,y);
}
}
}
printf("%d\n",ans);
return 0;
}
接下来应用这种思路写POJ的2492
题意:就是说有N个虫子,异性交配,但现在不知道虫子的性别,现在给出M个事件,问会不会出现同性交配的现象
思路:创建两个组,维护(x,y+n),(y,x+n)
#include<cstdio>
#include<cstring>
#include<cmath>
const int qq=2000+5;
int pre[qq*2];
void init(int n)
{
for(int i=0;i<=n*2;++i)
pre[i]=i;
}
int find(int x)
{
if(x==pre[x])
return x;
else
return pre[x]=find(pre[x]);
}
bool same(int a,int b)
{
return find(a)==find(b);
}
void un(int a,int b)
{
int x=find(a);
int y=find(b);
if(x==y)
return;
else
pre[x]=y;
}
int main()
{
int t;scanf("%d",&t);
int p=1;
while(t--){
printf("Scenario #%d:\n",p++);
int x,y,n,k;
scanf("%d%d",&n,&k);
init(n);
int flag=1;
for(int i=0;i<k;++i){
scanf("%d%d",&x,&y);
if(same(x,y)||same(y,x))
flag=0;
else{
if(flag){
un(x,y+n);
un(y,x+n);
}
}
}
if(flag)
printf("No suspicious bugs found!\n");
else
printf("Suspicious bugs found!\n");
if(t) printf("\n");
}
return 0;
}
POJ上刷题留心,题目如何给你一定要按照它的做,比如他只有一组数据输入,你别while(scanf("")!=EOF) 我就以为这样纠结了一个下午,
总之刷POJ一定要多留心,要多相信自己的代码,剩下的可能就是题目细节方面的错误了
POJ 1182食物链、的更多相关文章
- poj 1182 食物链 (带关系的并查集)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44835 Accepted: 13069 Description 动 ...
- poj 1182:食物链(种类并查集,食物链问题)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44168 Accepted: 12878 Description ...
- POJ 1182 食物链
G - 食物链 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit Stat ...
- POJ 1182 食物链(种类并查集)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 63592 Accepted: 18670 Description ...
- POJ 1182 食物链(经典带权并查集 向量思维模式 很重要)
传送门: http://poj.org/problem?id=1182 食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: ...
- POJ 1182——食物链——————【种类并查集】
食物链 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit Status P ...
- POJ 1182 食物链 [并查集 带权并查集 开拓思路]
传送门 P - 食物链 Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Submit ...
- 【原创】poj ----- 1182 食物链 解题报告
题目地址: http://poj.org/problem?id=1182 题目内容: 食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submi ...
- poj 1182 食物链 (并查集)
http://poj.org/problem?id=1182 关于并查集 很好的一道题,开始也看了一直没懂.这次是因为<挑战程序设计竞赛>书上有讲解看了几遍终于懂了.是一种很好的思路,跟网 ...
- POJ 1182 食物链(并查集拆点)
[题目链接] http://poj.org/problem?id=1182 [题目大意] 草原上有三种物种,分别为A,B,C A吃B,B吃C,C吃A. 1 x y表示x和y是同类,2 x y表示x吃y ...
随机推荐
- 属性中id和name的区别
id 在HTML中的作用: 1.用id选择相应的style sheet(风格). 2. <A ..> 链接的目的地 3.脚本语言用它找目的地(找该id的标签 ...
- Hdu 1498 二分匹配
50 years, 50 colors Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- Ajax.dll使用方法和步骤(比较方便的实现ajax)
转载自 博客频道 - CSDN.NET http://blog.csdn.net/houhanxin1/article/details/6671470 1. 有直接用框架的:Ajaxpro和Aja ...
- IntelliJ Idea 复制粘贴的问题
分析 尝试从外部复制内容向Idea工作空间内粘贴文件时,有一定的几率会发生复制粘贴失败的问题:复制了新的内容,粘贴的却还是早些时候复制的旧的内容. 我使用的IDEA是最新版(2016.1.3),操作系 ...
- input输入框限制录入类型
输入大小写字母.数字.下划线:<input type="text" onkeyup="this.value=this.value.replace(/[^\w_]/g ...
- Notepad++ ssh NppFTP链接linux
Notepad++是一套非常有特色的自由软件的纯文字编辑器,有完整的中文化接口及支持多国语言编写的功能.现在用Notepad++来远程编辑Linux系统文本文件. Notepad++ 1.Linux操 ...
- Linux下配置 Keepalived(心跳检测部署)
首先呢,我想先给大家简单介绍一下什么是keepalived: Keepalived的作用是检测服务器的状态,如果有一台web服务器死机,或工作出现故障,Keepalived将检测到,并将有故障的服务器 ...
- UVA_694:The Collatz Sequence
Language: C++ 4.8.2 #include<stdio.h> int main(void) { long long int m, n, copy_m; ; ; ) { sca ...
- vue vscode属性标签不换行
"vetur.format.defaultFormatterOptions": { "js-beautify-html": { "wrap_attri ...
- 注意特殊情况!最长上升子序列!!poj2533
poj 2533 简单的动归.用O(n^2)的算法也能过.但是有个细节!刚开始ans初始化为0时是错的!!!要初始化为1.因为只有1个数的时候,下面的循环是不会执行的.....或者特判.. #incl ...