因为是中文题,题意就不说了,直接说思路

我们不知道给的说法中的动物属于A B C哪一类,所以我们可以用不同区间的数字表示这几类动物,这并不影响结果,我们可以用并查集把属于一类的动物放在一块,举个例子:

A    2*n ~ 3*n-1

B    n ~ 2*n-1

C   0 ~ n-1

假设 n =10,1和3是同类,那么1和3并到一块,11和13并到一块,21和23并到一块。那么这样既不相互矛盾,又把这三种动物的可能性列举了出来。1捕食4,那么说明1比4高了一个等级,将1和14归并为一类,11和24归并为一类,21和4归并为一类,即B吃C,A吃B,C吃A。

看代码:

#include<stdio.h>
int f[160001];
int getf(int v)
{
if(f[v]==v)
return v;
return f[v]=getf(f[v]);
}
void marge(int u,int v)
{
int t1=getf(u),t2=getf(v);
if(t1!=t2)
f[t2]=t1;
}
bool same(int u,int v)
{
int t1=getf(u),t2=getf(v);
if(t1!=t2)
return 0;
return 1;
}
int main()
{
//A 2*n ~ 3*n-1 //B n ~ 2*n-1 //C 0~ n-1
int n,m,sum,a,b,p;
scanf("%d%d",&n,&m);
for(int i=0; i<n*3+10; i++)
f[i]=i;
sum=0;
for(int i=0; i<m; i++)
{
scanf("%d%d%d",&p,&a,&b);
a-=1,b-=1;
if(a>=n||b>=n||b<0||a<0)
{
sum++;
continue;
}
if(p==1)
{
if(same(a,b+n)||same(a,b+2*n))//a和b不能有捕食和被捕食的关系
sum++;
else
{
marge(a,b);//同一等级
marge(a+n,b+n);
marge(a+2*n,b+2*n);
}
}
else if(p==2)
{
if(same(a,b)||same(a,b+2*n))//a和不能是同类 也不能是b捕食a
sum++;
else//a捕食b表示a和b+n是同一等级
{
marge(a,b+n);
marge(a+n,b+2*n);
marge(a+2*n,b);
}
}
}
printf("%d\n",sum);
return 0;
}

poj——1182食物链 并查集(提升版)的更多相关文章

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

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

  2. poj 1182 食物链 并查集 题解《挑战程序设计竞赛》

    地址 http://poj.org/problem?id=1182 题解 可以考虑使用并查集解决 但是并不是简单的记录是否同一组的这般使用 每个动物都有三个并查集 自己 天敌 捕食 并查集 那么在获得 ...

  3. POJ 1182 食物链(并查集的使用)

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

  4. poj 1182 食物链 并查集的又一个用法

    食物链   Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 41584   Accepted: 12090 Descripti ...

  5. POJ 1182食物链(并查集)

    食物链Time Limit: 1000MS Memory Limit: 10000KTotal Submissions: 85474 Accepted: 25549Description动物王国中有三 ...

  6. POJ - 1182 食物链 并查集经典

    思路:设r(x)表示节点x与根结点的关系,px表示x的根结点.记录每个节点与其父节点的关系,就能很方便知道每个节点以及和它的父节点的关系. struct node{ int par; //父亲节点 i ...

  7. POJ 1182 食物链 (并查集)

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

  8. POJ 1182 食物链(并查集)

    题目链接 经过宝哥的讲解,终于对这种问题有了进一步的理解.根据flag[x]和flag[y]求flag[tx]是最关键的了. 0吃1,1吃2,2吃0. 假设flag[tx] = X; 那么X + fl ...

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

    题目传送门:http://poj.org/problem?id=1182 这是一道关系型并查集的题,对于每个动物来说,只有三种情况:同类,吃与被吃: 所以可以用0,1,2三个数字代表三种情况,在使用并 ...

随机推荐

  1. python基础知识的重新认识

    昨天模拟书本上client和server交互的例子,代码明明是按照书上写的,可是就是出现了错误,像下面这样: # tcpserver from socket import * from time im ...

  2. proxyTable的配置

    在dev环境下面: proxyTable: { '/api': { target: 'http://api.douban.com/v2', //主域名,以前我都写192.168.2.57:80,这里跨 ...

  3. Netty学习(4):NIO网络编程

    概述 在 Netty学习(3)中,我们已经学习了 Buffer 和 Channel 的概念, 接下来就让我们通过实现一个 NIO 的多人聊天服务器来深入理解 NIO 的第 3个组件:Selector. ...

  4. 20 本地SQL查询

    Spring Data JPA同样也支持sql语句的查询 //nativeQuery : 使用本地sql的方式查询 @Query(value="select * from customer& ...

  5. golang Printf 函数有超过 10 个转义字符

    verb 描述 %d 十进制整数 %x, %o, %b 十六进制.八进制.二进制整数 %f, %g, %e 浮点数:如 3.141593, 3.141592653589793, 3.141593e+0 ...

  6. C#窗体排列方式

    2020-03-11 每日一例第3天 1.设置父窗体属性:IsMdicontainer设置成true; 2.拖入menustrip控件,修改标题栏中的text文字. 3.点击“加载子窗体”设置代码: ...

  7. 数据结构 - ArrayList

    简介 ArrayList是一个动态数组.ArrayList几乎拥有数组所有优点,例如元素有序,索引访问等:并且一般情况下它还不会越界,添加元素时它能动态扩容.平时工作中ArrayList被我们广泛应用 ...

  8. centeos安装Anconda3

    步骤: #获取安装包 wget https://mirrors.tuna.tsinghua.edu.cn/anaconda/archive/Anaconda3-5.2.0-Linux-x86_64.s ...

  9. webpack资料,还需整理

    参考地址: https://github.com/ruanyf/webpack-demos#demo01-entry-file-source http://www.jianshu.com/p/4df9 ...

  10. [Microsoft Teams]使用连接器接收Azure Devops的通知

    1. 什么是连接器 连接器(connector)是Teams中频道的一个接受消息的功能,官方的解释如下: 连接器允许用户订阅来自 web 服务的接收通知和消息. 它们公开服务的 HTTPS 终结点,通 ...