poj1182食物链--并查集
现有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
#include<iostream>
#include<stdio.h>
#define maxn 50005*3
using namespace std;
int kind[maxn];
int rank[maxn];
void init()
{
for(int i=;i<maxn;i++)
kind[i]=i,rank[i]=;
}
int findp(int x)
{
if(kind[x]==x) return x;
else return kind[x]=findp(kind[x]);
}
void unit(int x,int y)
{
x=findp(x);
y=findp(y);
if(x==y) return;
if(rank[x]<rank[y])
{
kind[x]=y;
}
else
{
kind[y]=x;
if(rank[x]==rank[y]) rank[x]++;
}
}
bool same(int x,int y)
{
int ax=findp(x);
int ay=findp(y);
if(ax==ay) return true;
else return false; }
int main()
{
int n,k;
int type,x,y;
cin>>n>>k;
init();
int ans=;
for(int i=;i<k;i++)
{ scanf("%d%d%d",&type,&x,&y);
if(x<||x>n||y<||y>n)
{
ans++;
continue;
}
if(type==)
{
if(same(x,y+n)||same(x,y+n+n))
{
ans++;
continue;
}
unit(x,y);
unit(x+n,y+n);
unit(x+*n,y+*n);
}
else
{
if(x==y)
{
ans++;
continue;
}
if(same(x,y)||same(x,y+n+n))
{
ans++;
continue;
}
unit(x,y+n);
unit(x+n,y+n+n);
unit(x+n+n,y); }
}
printf("%d\n",ans);
return ;
}
这道题之前做过,大神们用位运算+%3关系,当时搞明白了,不过又忘记了,重新做了一遍。思路来自:挑战程序竞赛。
我们维护三个关系:i-a,i-b,i-c。
分别表示i属于a,b,c.
如果x,y是同一物种,我们将(x-a,y-a),(x-b,y-b),(x-c,y-c)unit一下。
如果x吃y,则(x-a,y-b),(x-b,y-c),(x-c,y-a)unit
当然,在unit之前我们考虑一下是否为假话:
若同一物种:
假话的情况:x被y吃---》(x-a,y-b)
y被x吃--》(x-a,y-c)
若捕食关系x吃y,假话情况:
x,y同一物种:(x-a,y-a)
y吃x:(x-a,y-c)
这样利用并查集维护三个集合。最终ac。
poj1182食物链--并查集的更多相关文章
- POJ-1182 食物链 并查集(互相关联的并查集写法)
题目链接:https://cn.vjudge.net/problem/POJ-1182 题意 中文题目,就不写了哈哈 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃 ...
- [poj1182]食物链(并查集+补集)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64841 Accepted: 19077 Description ...
- POJ-1182 食物链---并查集(附模板)
题目链接: https://vjudge.net/problem/POJ-1182 题目大意: 中文题,不多说. 思路: 给每个动物创建3个元素,i-A, i-B, i-C i-x表示i属于种类x,并 ...
- POJ1182 食物链 并查集
#include<iostream>#include<stdio.h>#include<string.h>using namespace std;const int ...
- 编程算法 - 食物链 并查集 代码(C)
食物链 并查集 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 有N仅仅动物, 分别编号为1,2,...,N. 全部动物都属于A,B,C中的一种 ...
- POJ1182:食物链(并查集)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 94930 Accepted: 28666 Description ...
- 【poj1182】食物链--并查集扩展域
Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 109341 Accepted: 33191 Description 动物 ...
- POJ-1182 分组并查集
今天刚发现,之前做的并查集只是贴模板基本就能过,题意改变一点,自己还是不懂,其实我还没入门呢... 题意:食物链,A吃B,B吃C,C吃A,输入m组数据: 1 a b:a 和 b 是同一类 2 a b: ...
- POJ 1182 (经典食物链 /并查集扩展)
(參考他人资料) 向量偏移--由"食物链"引发的总结 http://poj.org/problem?id=1182这道食物链题目是并查集的变型.非常久曾经做的一次是水过的,这次 ...
随机推荐
- C/C++中的格式化字符
格式化输出函数包括printf, fprintf, sprintf等等. 格式化输入函数包括scanf, fscanf, sscanf等等. 这类函数在输入输出的时候都有一个参数为格式化字符串(for ...
- Android LayoutInflater布局填充器
Android LayoutInflater布局填充器 把一份xml布局文件转为View对象,这就是layoutinflater的作用. 对于一个没有被载入或者想要动态载入的界面,都需要使用Layou ...
- distance field(占坑
signed distance field https://kosmonautblog.wordpress.com/2017/05/09/signed-distance-field-rendering ...
- xml文件中配置JDBC源遇到问题 : The reference to entity "characterEncoding" must end with the ';' delimiter
数据源配置时加上编码转换格式后出问题了: The reference to entity"characterEncoding" must end with the ';' deli ...
- Node.js mm131图片批量下载爬虫1.01 增加断点续传功能
这里的断点续传不是文件下载时的断点续传,而是指在爬行页面时有时会遇到各种网络中断而从中断前的页面及其数据继续爬行的过程,这个过程和断点续传原理上相似故以此命名.我的具体做法是:在下载出现故障或是图片已 ...
- 【ACM】Fighting for HDU
#include <stdio.h> #include <stdlib.h> #define max 100 /* run this program using the con ...
- HTML学习笔记(五)
1. Javascript是一种脚本语言,它的作用是提供用户交互.动态更改内容.数据验证. 2. 我们使用script标签将javascript的语句嵌入到html文档中. 3 ...
- Lina Group
var query = from ll in proListRequestList group ll by new {ll.pro_id} into g select new ProListReque ...
- 五中不同的思路输出helloword
五中不同的思路输出helloword -- 我也不知道了--
- ES6 const用法
1.const声明一个只读的常量.一旦声明,常量的值就不能改变. 2.const的作用域与let命令相同:只在声明所在的块级作用域内有效. 3.const命令声明的常量也是不提升,只能在声明的位置后面 ...