POJ 1611 The Suspects(并查集)

本文介绍了一道关于并查集的经典算法题,并详细展示了如何使用C++实现该算法。通过具体的代码示例,读者可以了解到并查集的基本结构、合并及查找操作的实现方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:点击打开链接

简单的并查集,水题

// POJ 1611 The Suspects.cpp
#include <cstdio>
#include <cstring>
#include <iostream>
#include <vector>
using namespace std;
class DisjointSet {
private:
	int n;
	vector<int> fa, rank;
public:
	DisjointSet(int n) :n(n),fa(n), rank(n) {
		for (int i = 0; i < n; i++) {
			fa[i] = i;
			rank[i] = 0;
		}
	}
	int getFather(int x) {
		return fa[x] = (fa[x] == x ? x : getFather(fa[x]));
	}
	void merge(int x, int y) {
		int a = getFather(x);
		int b = getFather(y);
		if (a == b) {
			return;
		}
		if (rank[a] < rank[b]) {
			fa[a] = b;
		}
		else {
			fa[b] = a;
			if (rank[a] == rank[b]) {
				rank[a]++;
			}
		}
	}
	int count() {
		int cnt = 0;
		int re = getFather(0);
		for (int i = 0; i < n; i++) {
			if (getFather(i) == re) {
				cnt++;
			}
		}
		return cnt;
	}
};
int main(){
	int n, m, k, fir, te;
	while (scanf("%d%d", &n, &m) != EOF) {
		if (!n && !m) break;
		DisjointSet s(n);
		for (int i = 0; i < m; i++) {
			scanf("%d", &k);
			if (k) scanf("%d", &fir);
			for (int j = 0; j < k - 1; j++) {
				scanf("%d", &te);
				s.merge(fir, te);
			}
		}
		cout << s.count() << endl;
	}
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值