题目地址:HDU 2120
这题虽然字数不多,但就是看不懂。。意思是求最多有多少个被墙围起来的区域。显然就是求环的个数。然后用并查集求环个数就可以了。
代码如下:
#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <stdlib.h>
#include <math.h>
#include <ctype.h>
#include <queue>
#include <map>
#include <set>
#include <algorithm>
using namespace std;
int bin[2000];
int find1(int x)
{
return bin[x]==x?x:bin[x]=find1(bin[x]);
}
int main()
{
int n, m, ans, a, b, f1, f2, i;
while(scanf("%d%d",&n,&m)!=EOF)
{
ans=0;
for(i=0;i<n;i++)
bin[i]=i;
while(m--)
{
scanf("%d%d",&a,&b);
f1=find1(bin[a]);
f2=find1(bin[b]);
if(f1==f2)
ans++;
else
bin[f2]=f1;
}
printf("%d\n",ans);
}
return 0;
}
标签:bin,2120,HDU,int,查集,ans,include,find1 From: https://blog.51cto.com/u_16070138/6188254