poj 2492A Bug's Life(并查集)

简介:
/*
目大意:输入一个数t,表示测试组数。然后每组第一行两个数字n,m,n表示有n只昆虫,编号从1—n,m表示下面要输入m行交配情况,每行两个整数,表示这两个编号的昆虫为异性,要交配。
要求统计交配过程中是否出现冲突,即是否有两个同性的昆虫发生交配。

思路:并查集
   将同性的昆虫放入集合之中,如果输入的昆虫u, v同时出现在了集合中,那么 u,v就是同性的!发生了同性交配的可能!
*/

#include <string>
#include <cstdio>
#include <cstring>
#include <iostream>



using namespace std;
int n, m;
int f[2010];
int  mark[2010];//mark[i]表示 与 i 交配的昆虫的编号!

int getFather(int x){
   return x==f[x] ? x : f[x]=getFather(f[x]);
}

void Union(int a, int b){
    int fa=getFather(a), fb=getFather(b);
    if(fa!=fb)
       f[fa]=fb;
}

int main(){
   int t, cnt=0;
   scanf("%d", &t);
   while(t--){
      
          scanf("%d%d", &n, &m);
          for(int i=1; i<=n; ++i)
          f[i]=i;
      memset(mark, 0, sizeof(mark));
      int flag=1;
      while(m--){
             int u, v;
         scanf("%d%d", &u, &v);
         if(flag){
            if(getFather(u) == getFather(v)){
               flag=0;
                           continue;
             }   
                        if(!mark[u] && !mark[v]){
                   mark[u]=v;
                   mark[v]=u;
                 }
                else if(!mark[u]){
                   mark[u]=v;
                   Union(u, mark[v]); //如果v配对了,u没有配对,那么u和mark[v]就是同性昆虫,放入集合之中
            }
                 else if(!mark[v]){
                   mark[v]=u;        
                   Union(v,mark[u]);//,,,,,,
                }
               else{ 
                  Union(u, mark[v]);//如果之前u和v都已经配对,现在u和v进行配对, 那么u和mark[v]是同性, v和mark[u]是同性!
              Union(v, mark[u]);
               }
         }
      }
      printf("Scenario #%d:\n",++cnt);
        if (flag==1) 
            printf("No suspicious bugs found!\n");
        else
            printf("Suspicious bugs found!\n");
        printf("\n");
   }
}









本文转自 小眼儿 博客园博客,原文链接:http://www.cnblogs.com/hujunzheng/p/3892002.html,如需转载请自行联系原作者
目录
相关文章
|
5月前
【洛谷 P1219】[USACO1.5]八皇后 Checker Challenge 题解(深度优先搜索+回溯法)
**USACO1.5八皇后挑战**是关于在$n\times n$棋盘上放置棋子的,确保每行、每列及两条主对角线上各有一个且仅有一个棋子。给定$6$作为输入,输出前$3$个解及解的总数。例如,对于$6\times6$棋盘,正确输出应包括解的序列和总数。代码使用DFS解决,通过跟踪对角线占用状态避免冲突。当找到所有解时,显示前三个并计数。样例输入$6$产生输出为解的前三个排列和总数$4$。
37 0
|
网络架构
POJ 3250 Bad Hair Day、POJ 2796 Feel Good(单调栈)
POJ 3250 Bad Hair Day、POJ 2796 Feel Good(单调栈)
|
SQL Shell
HDU-4348 To the moon(主席树区间修改 永久化标记)
HDU-4348 To the moon(主席树区间修改 永久化标记)
141 0
HDU-4348 To the moon(主席树区间修改 永久化标记)
|
人工智能 Java
[HDU 7136] Jumping Monkey | 并查集 | 逆向思维
Jumping Monkey Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) Total Submission(s): 747 Accepted Submission(s): 360
222 0
[HDU 7136] Jumping Monkey | 并查集 | 逆向思维
POJ-2492,A Bug's Life(分类并查集)
POJ-2492,A Bug's Life(分类并查集)