ArcTan

dfs
随笔 - 16, 文章 - 117, 评论 - 6, 引用 - 0
数据加载中……

poj 1182食物链(并查集的应用)

并查集好经典的应用,搞明白这个题目,可以秒杀POJ所有并查集题目!

struct node{
      
int father;根节点
      
int relation;与根节点关系:0 同类,1吃根节点,2被吃
} line[maxn];

int find(int x)
{
      
if (x!=line[x].father)
      {
            
int tmp=line[x].father;
            line[x].father
=find(tmp);
            
//找规律,求出公式
            num[x]=(line[x].relation+line[tmp].relation) % 3;        
       }
      returen line[x].father;
}
void union(int x,int y,int d)
{
      
int fx=find(x);
      
int fy=find(y);
      line[fx].father
=fy;
       
//找规律,求出公式
      line[fx].relation=(line[y].relation-line[x].relation+2+d) % 3;    
      
return ;
}

Thinking && Coding!!!

#include <cstdio>
#include 
<cstdlib>
#include 
<cstring>
#include 
<cmath>
#include 
<ctime>
#include 
<cassert>
#include 
<iostream>
#include 
<sstream>
#include 
<fstream>
#include 
<map>
#include 
<set>
#include 
<vector>
#include 
<queue>
#include 
<algorithm>
#define min(x,y) (x<y?x:y)
#define max(x,y) (x>y?x:y)
#define swap(t,x,y) (t=x,x=y,y=t)
#define clr(list) memset(list,0,sizeof(list))
#define maxn 50005
using namespace std;
int father[maxn];
int num[maxn];
int find(int x)
{
    
if (x!=father[x])
    {
        
int tmp=father[x];
        father[x]
=find(father[x]);
        num[x]
=(num[x]+num[tmp]) % 3;
    }
    
return father[x];
}
void union_set(int x,int y,int d)
{
    
int fx=find(x);
    
int fy=find(y);
    father[fx]
=fy;
    num[fx]
=(num[y]-num[x]+2+d) % 3;
    
return ;
}
int main()
{
    
int n,m;
    scanf(
"%d%d",&n,&m);

    
int ans=0;
    
int flag=0;
    
for (int i=1; i<=n; i++)
        father[i]
=i,num[i]=0;
    
for (int i=1; i<=m; i++)
    {
        
int d,x,y;
        scanf(
"%d%d%d",&d,&x,&y);
        
if (x>|| y>n)
        {
            ans
++;
            
continue;
        }
        
if (d==2 && x==y)
        {
            ans
++;
            
continue;
        }
        
int fx=find(x);
        
int fy=find(y);
        
if (d==2 && fx==fy)
        {
            
if ((num[x]-num[y]+3)%3!=1)
                ans
++;
            
continue;
        }
        
if (d==1 && fx==fy && num[x]!=num[y])
        {
            ans
++;
            
continue;
        }
        union_set(x,y,d);
    }
    printf(
"%d\n",ans);
    
return 0;
}





posted on 2012-07-26 21:51 wangs 阅读(218) 评论(0)  编辑 收藏 引用 所属分类: ACM-数据结构


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理