POJ 1182 并查集
2011-07-14 02:50
225 查看
对于这道题,我真是一肚子苦逼啊。
对于一个刚接触并查集的菜鸟,手贱地随便找了一道并查应用的题目想练一下手,但是没想到搜到这道题,这题真不基础啊。
基本上都是别人的代码。
不过这个题目让我最大的收获就是:特别是递归的题目,看别人代码的时候要自己代入数据去跟着程序跑思路,这样才能理解的快。否则真是很容易抓狂。
#include<iostream>
using namespace std;
const int N=50005;
const int K=100005;
int n,k,x,y,d,wrg=0;
int parent
;
int kind
;
int find(int x)
{
if(parent[x]!=0)
{
int t=parent[x];
parent[x]=find(parent[x]);
kind[x]=(kind[t]+kind[x])%3;
}
else
return x;
return parent[x];
}
void unionone(int a,int b)
{
int aa=find(a),bb=find(b);
parent[bb]=aa;
kind[bb]=(kind[a]-kind[b]+d-1+3)%3;
}
bool check()
{
if(x>n||y>n||(d==2&&x==y))
return false;
if(d==1)
{
if(find(x)==find(y))
{
if(kind[x]==kind[y])
return true;
else
return false;
}
else
{
unionone(x,y);
return true;
}
}
else //d==2
{
if(find(x)==find(y))
{
if((kind[y]-kind[x]+3)%3==1)
return true;
else
return false;
}
else
{
unionone(x,y);
return true;
}
}
}
int main()
{
//freopen("C:\\Users\\wuyanyisb\\Desktop\\1.txt","r",stdin);
scanf("%d%d",&n,&k);
for(int i=1;i<=k;i++)
{
scanf("%d%d%d",&d,&x,&y);
if(!check())
wrg++;
}
printf("%d",wrg);
system("pause");
return 0;
}
对于一个刚接触并查集的菜鸟,手贱地随便找了一道并查应用的题目想练一下手,但是没想到搜到这道题,这题真不基础啊。
基本上都是别人的代码。
不过这个题目让我最大的收获就是:特别是递归的题目,看别人代码的时候要自己代入数据去跟着程序跑思路,这样才能理解的快。否则真是很容易抓狂。
#include<iostream>
using namespace std;
const int N=50005;
const int K=100005;
int n,k,x,y,d,wrg=0;
int parent
;
int kind
;
int find(int x)
{
if(parent[x]!=0)
{
int t=parent[x];
parent[x]=find(parent[x]);
kind[x]=(kind[t]+kind[x])%3;
}
else
return x;
return parent[x];
}
void unionone(int a,int b)
{
int aa=find(a),bb=find(b);
parent[bb]=aa;
kind[bb]=(kind[a]-kind[b]+d-1+3)%3;
}
bool check()
{
if(x>n||y>n||(d==2&&x==y))
return false;
if(d==1)
{
if(find(x)==find(y))
{
if(kind[x]==kind[y])
return true;
else
return false;
}
else
{
unionone(x,y);
return true;
}
}
else //d==2
{
if(find(x)==find(y))
{
if((kind[y]-kind[x]+3)%3==1)
return true;
else
return false;
}
else
{
unionone(x,y);
return true;
}
}
}
int main()
{
//freopen("C:\\Users\\wuyanyisb\\Desktop\\1.txt","r",stdin);
scanf("%d%d",&n,&k);
for(int i=1;i<=k;i++)
{
scanf("%d%d%d",&d,&x,&y);
if(!check())
wrg++;
}
printf("%d",wrg);
system("pause");
return 0;
}
相关文章推荐
- NYOJ 207 POJ 1182 带权并查集做法(√)
- POJ 1182 食物链 并查集
- poj 1182 并查集
- POJ-1182 食物链 并查集(互相关联的并查集写法)
- 并查集(poj1611、2524、2492、1182)
- Poj(1182),种类并查集
- 笔记②:并查集算法解析及其高级运用(POJ1182 食物链代码解析)
- POJ[1182]食物链 加权并查集
- POJ-1182-食物链(并查集经典题)
- POJ 1182 食物链(种类并查集)
- poj 1182--食物链(并查集,向量偏移)
- POJ-1182食物链(并查集的运用)
- poj 1182 食物链(带权并查集)
- poj 1182 (带权并查集)
- poj 1182 并查集
- POJ 1182 食物链——并查集
- POJ-1182 食物链 经典并查集
- 【POJ】1182 - 食物链(带权并查集,单数据)
- POJ1182--带权并查集
- poj 1182 【经典并查集】 和【不一样的解法】