给定几条边,需求出还需几条使节点连成无向连通图c++代码
时间: 2023-12-21 12:15:08 浏览: 62
以下是一个简单的 C++ 代码示例,使用 Kruskal 算法来计算需要添加的边数:
```c++
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<int> parent;
int find(int i) {
if (parent[i] == i) {
return i;
}
return parent[i] = find(parent[i]);
}
void unionSet(int x, int y) {
parent[find(x)] = find(y);
}
int addEdgesToMakeConnected(int n, vector<vector<int>>& edges) {
// 初始化每个节点的父节点
parent.resize(n);
for (int i = 0; i < n; i++) {
parent[i] = i;
}
int num_edges = edges.size();
for (int i = 0; i < num_edges; i++) {
int x = find(edges[i][0]);
int y = find(edges[i][1]);
if (x != y) {
unionSet(x, y);
}
}
// 计算需要添加的边数
int num_add_edges = 0;
for (int i = 0; i < n; i++) {
if (parent[i] == i) {
num_add_edges++;
}
}
return num_add_edges - 1;
}
int main() {
int n = 5;
vector<vector<int>> edges{{0, 1}, {1, 2}, {3, 4}};
int num_add_edges = addEdgesToMakeConnected(n, edges);
cout << num_add_edges << endl; // 输出 1,需要再添加一条边
return 0;
}
```
其中,参数 `n` 表示节点数,参数 `edges` 是一个二维数组,包含给定的边,每条边是一个由两个节点组成的数组。函数 `addEdgesToMakeConnected` 返回需要添加的边数,使所有节点连成一个无向连通图。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/10214/10214c21be157c7ee09c5af8793db42d5f2aee45" alt="txt"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="doc"
data:image/s3,"s3://crabby-images/5402c/5402c08311ac4060fea3813aa755d24bfad9113e" alt="h"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/4ab4e/4ab4e16af55d61505c6ba78cf12ec100586fa6ad" alt="7z"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="pdf"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/10214/10214c21be157c7ee09c5af8793db42d5f2aee45" alt="txt"
data:image/s3,"s3://crabby-images/4ab4e/4ab4e16af55d61505c6ba78cf12ec100586fa6ad" alt="7z"
data:image/s3,"s3://crabby-images/10214/10214c21be157c7ee09c5af8793db42d5f2aee45" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="-"