应用挑战程序设计那本书上的话:

  对于每只动物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食物链、的更多相关文章

  1. poj 1182 食物链 (带关系的并查集)

      食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44835 Accepted: 13069 Description 动 ...

  2. poj 1182:食物链(种类并查集,食物链问题)

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

  3. POJ 1182 食物链

    G - 食物链 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit Stat ...

  4. POJ 1182 食物链(种类并查集)

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

  5. POJ 1182 食物链(经典带权并查集 向量思维模式 很重要)

    传送门: http://poj.org/problem?id=1182 食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: ...

  6. POJ 1182——食物链——————【种类并查集】

    食物链 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit Status P ...

  7. POJ 1182 食物链 [并查集 带权并查集 开拓思路]

    传送门 P - 食物链 Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Submit  ...

  8. 【原创】poj ----- 1182 食物链 解题报告

    题目地址: http://poj.org/problem?id=1182 题目内容: 食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submi ...

  9. poj 1182 食物链 (并查集)

    http://poj.org/problem?id=1182 关于并查集 很好的一道题,开始也看了一直没懂.这次是因为<挑战程序设计竞赛>书上有讲解看了几遍终于懂了.是一种很好的思路,跟网 ...

  10. 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 ...

随机推荐

  1. linux系统RabbitMQ启动错误记录

    安装并配置好RabbitMq之后终端执行rabbitmq-server报错 试了网上的各种方法也无济于事 最后发现可能是因为访问权限的问题(并不确定) 解决方法:sudo rabbitmq-serve ...

  2. ASP.NET CORE使用MailKit的一个故障点分析

    ASP.NET CORE下有需要发邮件的需求,但是原来framework下的 system.net.mail,没有实现smtpclient的功能(当时看是没有,说是准备并入.net core来着),所 ...

  3. 手机端点击键盘无法获取keyCode值的部分时隐藏键盘并执行事件

    用计时器监视window.innerHeight高度改变来判断.触发键盘其他地方也有事件反应 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...

  4. Python 字符编码处理总结

    Python中经常遇到这样那样的字符编码问题,尤其在处理网页源码时(特别是爬虫中): UnicodeDecodeError: 'XXX' codec can't decode bytes in pos ...

  5. 关于父组件通过v-on接收子组件多个参数的一点研究

    写组件的时候遇到一个需求,我需要在子组件向父组件传递信息 this.$emit('myEvent', 信息1, 信息2) 在父组件使用v-on来接收 <my-component @myEvent ...

  6. 掀开SQL的神秘面纱,将优化进行到底

    掀开SQL的神秘面纱,将优化进行到底 有这样一条奇怪的SQL,返回结果不足10行,逻辑读达到1.2w,存在索引却走多次全表扫描,如何揭开它神秘的面纱拯救系统性能,答案在这里,你不可错过! 本文来自上周 ...

  7. Directx11教程(35) 纹理映射(5)

    原文:Directx11教程(35) 纹理映射(5)     到现在为止,我们的TextureClass初始化函数非常简单,说白了就是一行代码: result = D3DX11CreateShader ...

  8. Directx教程(26) 简单的光照模型(5)

    原文:Directx教程(26) 简单的光照模型(5)     在前面的工程中,我们都是在vs中实现顶点光照计算,然后再把顶点颜色传到ps中.本章中我们尝试fragment光照(或者说叫ps光照),在 ...

  9. Directx11教程(14) D3D11管线(3)

    原文:Directx11教程(14) D3D11管线(3)       现在我们开始学习一些CP(command processor)的知识.参考资料: http://fgiesen.wordpres ...

  10. iOS 小 Tip:优化侧滑返回与 ScrollView 的兼容性

    http://www.cocoachina.com/ios/20150909/13369.html 作者:@周楷雯Kevin 授权本站转载. 倘若在 ViewController 中添加了一个 Tab ...