在C++中,可以通过以下方式实现并查集(Disjoint Set):
#include <vector>
class DisjointSet {
public:
DisjointSet(int n) {
parent.resize(n);
rank.resize(n, 0);
for (int i = 0; i < n; ++i) {
parent[i] = i;
}
}
int find(int u) {
if (parent[u] != u) {
parent[u] = find(parent[u]);
}
return parent[u];
}
void merge(int u, int v) {
int pu = find(u);
int pv = find(v);
if (pu != pv) {
if (rank[pu] < rank[pv]) {
parent[pu] = pv;
} else if (rank[pu] > rank[pv]) {
parent[pv] = pu;
} else {
parent[pu] = pv;
rank[pv]++;
}
}
}
private:
std::vector<int> parent;
std::vector<int> rank;
};
使用示例:
#include <iostream>
int main() {
DisjointSet ds(5);
ds.merge(0, 1);
ds.merge(1, 2);
ds.merge(3, 4);
std::cout << ds.find(2) << std::endl; // Output: 0
std::cout << ds.find(4) << std::endl; // Output: 3
return 0;
}
在上面的示例中,定义了一个DisjointSet类,包含了find和merge两个方法,分别用于查找元素所在的集合和合并两个集合。可以根据实际需求进行修改和扩展。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。