您好,登錄后才能下訂單哦!
在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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。