/*
input
n,m,已知有n个城市,有m条道路.
output
m行,第i行对应删去输入的前i行之后,城市的连通度。
思路:从输入的m条边倒着数,
若删完,结果应为n。
从下往上,添加边,若两点不在一个集合中,结果--;
注意:题目没说是一组还是多组用例,这就很尴尬了。
经测验是多组用例。。。。
还有注意数组越界问题,题目n,m范围,以及城市编号是从0到n-1
*/
#include <cstdio>
#include <algorithm>
#define N 10005
#define M 100050
using namespace std;
int n, m;
int a[M], b[M];
int ans[M];
int f[N];
void init()
{
for (int i = 0; i < n; i++)
f[i] = i;
}
int find(int x)
{
return x == f[x] ? x : f[x] = find(f[x]);
}
int merge(int x, int y)
{
int t1, t2;
t1 = find(x); t2 = find(y);
if (t1 != t2)
{
f[t2] = t1;
return 1;
}
return 0;
}
int main()
{
while (scanf("%d%d", &n, &m) != EOF)
{
for (int i = 0; i < m; i++)
scanf("%d%d", &a[i], &b[i]);
init();
int tmp = n;
for (int i = m - 1; i >= 0; i--)
{
ans[i] = tmp;
if (find(a[i]) != find(b[i]))//当前两城镇不连通
tmp--;
merge(a[i], b[i]);//连接两城镇
}
for (int i = 0; i < m; i++)
printf("%d\n", ans[i]);
}
return 0;
}
hdu4496
最新推荐文章于 2017-07-20 09:51:00 发布