首页 > 其他 > 详细

POJ 1703 Find them, Catch them

时间:2014-07-29 13:18:17      阅读:277      评论:0      收藏:0      [点我收藏+]

种类并查集!!!

这里使用的两段区间求法!!两种种类并查集比较好理解,就是和你不同类的两个就是同类!!

bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣表情分界线bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣bubuko.com,布布扣


AC代码如下:


#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <cstring>
#include <cmath>
#define inf 2000000000
#define linf 1000000000000000000LL
#define dinf 1e200
#define pb push_back
#define mp make_pair
#define ll long long
#define sq(a) ((a)*(a))
#define ff(i,xi,n) for(int i=xi;i<=(int)(n);++i)
#define ffd(i,xi,n) for(int i=xi;i>=(int)(n);--i)
#define ffl(i,r) for(int i=head[r];i!=-1;i=edge[i].next)
#define ms(i,j) memset(i,j,sizeof(i))
#define M 200010
using namespace std;

int fa[M];

int findfa(int a)
{
    return a==fa[a]?a:fa[a]=findfa(fa[a]);
}

int main()
{
    int n,m;
    int t;
    char c;
    int a,b;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d%d",&n,&m);getchar();
        ff(i,0,2*n) fa[i]=i;
        ff(i,1,m) {scanf("%c%d%d",&c,&a,&b);getchar();
        if(c=='A'){
            if(findfa(a)==findfa(b))
                {printf("In the same gang.\n");continue;}
            if(findfa(a+n)==findfa(b)||findfa(a)==findfa(b+n))
                {printf("In different gangs.\n");continue;}
            printf("Not sure yet.\n");
        }
        else
        {
            fa[findfa(a)]=findfa(b+n);fa[findfa(b)]=findfa(a+n);//把不同类的放到后面区间去。
        }
        }
    }
    return 0;
}


POJ 1703 Find them, Catch them,布布扣,bubuko.com

POJ 1703 Find them, Catch them

原文:http://blog.csdn.net/hanhai768/article/details/38252315

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!