创建无向图邻接矩阵算法
时间: 2024-01-11 14:21:33 浏览: 90
在C++中,可以使用邻接矩阵来表示无向图。邻接矩阵是一个二维数组,其中的元素表示图中两个顶点之间的边的存在与否。
下面是一个简单的示例代码,展示了如何创建一个无向图的邻接矩阵:
```cpp
#include <iostream>
#include <vector>
using namespace std;
class Graph {
private:
int numVertices; // 图中顶点的数量
vector<vector<int>> adjMatrix; // 邻接矩阵
public:
// 构造函数
Graph(int num) {
numVertices = num;
adjMatrix.resize(numVertices, vector<int>(numVertices, 0));
}
// 添加边
void addEdge(int src, int dest) {
adjMatrix[src][dest] = 1;
adjMatrix[dest][src] = 1;
}
// 打印邻接矩阵
void printMatrix() {
for (int i = 0; i < numVertices; i++) {
for (int j = 0; j < numVertices; j++) {
cout << adjMatrix[i][j] << " ";
}
cout << endl;
}
}
};
int main() {
// 创建一个包含5个顶点的无向图
Graph graph(5);
// 添加边
graph.addEdge(0, 1);
graph.addEdge(0, 4);
graph.addEdge(1, 2);
graph.addEdge(1, 3);
graph.addEdge(1, 4);
graph.addEdge(2, 3);
graph.addEdge(3, 4);
// 打印邻接矩阵
graph.printMatrix();
return 0;
}
```
在上面的代码中,我们首先定义了一个`Graph`类,其中包含了私有成员变量`numVertices`表示图中顶点的数量,以及`adjMatrix`表示邻接矩阵。构造函数用于初始化邻接矩阵的大小。
然后,我们定义了`addEdge`函数用于添加边,这里我们使用1表示两个顶点之间存在边。注意,由于是无向图,所以我们需要同时在两个顶点之间设置边。
最后,我们定义了`printMatrix`函数用于打印邻接矩阵。
在`main`函数中,我们创建了一个包含5个顶点的无向图,并添加了一些边。然后,我们调用`printMatrix`函数打印邻接矩阵。
希望这个示例能够帮助你理解如何使用邻接矩阵来表示无向图。如果你有任何问题,请随时提问。
阅读全文