poj2492(种类并查集/各种解法)
题目链接: http://poj.org/problem?id=2492
题意: 有t组测试数据, 对于每组数据,第一行n, m分别表示昆虫的数目和接下来m行x, y,
x, y表示教授判断x, y为异性, 问教授是否有错误判断,即存在x, y为同性;
这道题和poj1703类似, 不过更简单一点 (poj1703题解)
解法1: 我们可以用rank[x]记录x与其父亲节点的关系, rank[x]=0表同性, rank[x]=1表异性;
假设前面的教授判断都是正确的, 若后面存在与前面判断矛盾的数据,那么教授判断有误;
代码:
#include <iostream>
#include <stdio.h>
#define MAXN 2010
using namespace std; int rank[MAXN], pre[MAXN]; //***rank[x]存储x与其父亲节点的关系 int find(int x){ //***递归压缩路径
if(x!=pre[x]){
int px=find(pre[x]);
rank[x]=(rank[x]+rank[pre[x]])%; //***跟新rank[x]
pre[x]=px;
}
return pre[x];
} int jion(int x, int y){
int px=find(x);
int py=find(y);
if(px==py){
if((rank[x]+rank[y])%==){ //**rank得出x, y的关系为同性,又由题意得出输入的x, y是异性, 矛盾
return ;
}else{
return ;
}
}else{
pre[py]=px; //**合并
rank[py]=(rank[x]+rank[y]+)%; //**更新rank[py]
}
return ;
} int main(void){
int t, m, n;
scanf("%d", &t);
for(int k=; k<=t; k++){
scanf("%d%d", &n, &m);
for(int i=; i<=n; i++){
pre[i]=i;
rank[i]=;
}
int flag=;
while(m--){
int x, y;
scanf("%d%d", &x, &y);
if(jion(x, y)){
flag=;
}
}
if(flag){
printf("Scenario #%d:\nSuspicious bugs found!\n\n", k);
}else{
printf("Scenario #%d:\nNo suspicious bugs found!\n\n", k);
}
}
return ;
}
解法2: 并查集里面合并同一性别的昆虫, 用n+x表示与x性别相反的昆虫
代码:
#include <iostream>
#include <stdio.h>
#define MAXN 2010
using namespace std; int pre[MAXN*]; int find(int x){ //***递归压缩路径
return x==pre[x]?pre[x]:pre[x]=find(pre[x]);
} void jion(int x, int y){//**合并
int px=find(x);
int py=find(y);
if(px!=py){
pre[px]=py;
}
} int main(void){
int t, m, n;
scanf("%d", &t);
for(int k=; k<=t; k++){
scanf("%d%d", &n, &m);
for(int i=; i<=*n; i++){
pre[i]=i;
}
int flag=;
while(m--){
int x, y;
scanf("%d%d", &x, &y);
if(find(x)==find(y)){
flag=;
}else{
jion(x, y+n);
jion(x+n, y);
}
}
if(flag){
printf("Scenario #%d:\nSuspicious bugs found!\n\n", k);
}else{
printf("Scenario #%d:\nNo suspicious bugs found!\n\n", k);
}
}
return ;
}
解法3: 用vis数组标记, vis[x]存储与x性别不同的昆虫
代码:
#include <iostream>
#include <stdio.h>
#define MAXN 2010
using namespace std; int pre[MAXN*], vis[MAXN*]; int find(int x){ //***递归压缩路径
return x==pre[x]?pre[x]:pre[x]=find(pre[x]);
} void jion(int x, int y){//***合并
int px=find(x);
int py=find(y);
if(px!=py){
pre[px]=py;
}
} int main(void){
int t, m, n;
scanf("%d", &t);
for(int k=; k<=t; k++){
scanf("%d%d", &n, &m);
for(int i=; i<=*n; i++){
pre[i]=i;
vis[i]=;
}
int flag=;
while(m--){
int x, y;
scanf("%d%d", &x, &y);
if(find(x)==find(y)){
flag=;
}else if(vis[x]+vis[y]==){ //***如果之前x, y都没有出现
vis[x]=y;
vis[y]=x;
}else if(!vis[x]){ //***x没有出现
vis[x]=y;
jion(x, vis[y]);
}else if(!vis[y]){ //***y没有出现
vis[y]=x;
jion(y, vis[x]);
}else{ //***都出现过
jion(x, vis[y]);
jion(vis[x], y);
}
}
if(flag){
printf("Scenario #%d:\nSuspicious bugs found!\n\n", k);
}else{
printf("Scenario #%d:\nNo suspicious bugs found!\n\n", k);
}
}
return ;
}
poj2492(种类并查集/各种解法)的更多相关文章
- POJ2492:A Bug's Life(种类并查集)
A Bug's Life Time Limit: 10000MS Memory Limit: 65536K Total Submissions: 45757 Accepted: 14757 题 ...
- POJ 1182食物链(分集合以及加权两种解法) 种类并查集的经典
题目链接:http://icpc.njust.edu.cn/Problem/Pku/1182/ 题意:给出动物之间的关系,有几种询问方式,问是真话还是假话. 定义三种偏移关系: x->y 偏移量 ...
- POJ1733 Parity game —— 种类并查集
题目链接:http://poj.org/problem?id=1733 Parity game Time Limit: 1000MS Memory Limit: 65536K Total Subm ...
- NOI2001|POJ1182食物链[种类并查集 向量]
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 65430 Accepted: 19283 Description ...
- NOIP2010关押罪犯[并查集|二分答案+二分图染色 | 种类并查集]
题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突.我们用“怨气值”(一个正整数值)来表示 ...
- POJ1703Find them, Catch them[种类并查集]
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 42416 Accepted: ...
- poj1417(种类并查集+dp)
题目:http://poj.org/problem?id=1417 题意:输入三个数m, p, q 分别表示接下来的输入行数,天使数目,恶魔数目: 接下来m行输入形如x, y, ch,ch为yes表示 ...
- poj1733(种类并查集+离散化)
题目链接: http://poj.org/problem?id=1733 题意: 输入n表示有一个长度为n的0,1字符串, m表示接下来有m行输入, 接下来的m行输入中x, y, even表示第x到第 ...
- poj 1182:食物链(种类并查集,食物链问题)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44168 Accepted: 12878 Description ...
随机推荐
- 9.4用WebApi去连接外部认证服务
原文链接:http://www.asp.net/web-api/overview/security/external-authentication-services VS2013和Asp.Net4.5 ...
- MyEclipse 2013优化配置【转】
作者:chszs,转载需注明.博客主页:http://blog.csdn.net/chszs MyEclipse 2013优化速度方案仍然主要有这么几个方面:去除无需加载的模块.取消冗余的配置.去除不 ...
- 解决Eclipse中文乱码
http://hsj69106.blog.51cto.com/1017401/595598 使用Eclipse编辑文件经常出现中文乱码或者文件中有中文不能保存的问题,Eclipse提供了灵活的设置文件 ...
- 使用update!导致的更新时候的错误信息不显示 ruby on rails
在图片管理里添加了校验方法之后,发现在更新的时候页面不显示校验报错的信息 class Picture < ApplicationRecord belongs_to :imageable, pol ...
- 对象的constructor属性
对象的constructor属性, 最初是用来标识对象类型的. 比如 ,我们定义一个 Person类,然后实例化两个对象. function Person(name, age, job){this.n ...
- hiho #1305 区间求差
#1305 : 区间求差 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定两个区间集合 A 和 B,其中集合 A 包含 N 个区间[ A1, A2 ], [ A3, ...
- map的4种遍历方式
System.out.println("key= "+ key + " and value= " + map.get(key)); } ...
- 2.实现Express中间件
Express提供的大部分功能都是通过中间件函数完成,这些中间件函数在Node.js收到 请求的时点 和 发送响应的时点 执行 connect模块提供了中间件框剪 方便在全局或路径级别或为单个路由插入 ...
- thinkphp save()方法没有数据,保存失败解决办法
thinkphp save()方法没有数据保存返回0,保存失败返回false 可以对返回值判断一下就好 $ret = $model->save($data); //var_dump($ret ...
- non
I p(I q){r p(c((q>9?q-p(q/10):q)+'0')),q*10; }