创建邻接矩阵图的C++代码
时间: 2024-05-16 07:16:10 浏览: 100
下面是一个简单的 C++ 代码示例,用于创建邻接矩阵图:
```c++
#include <iostream>
using namespace std;
int main() {
// 定义图的大小
int n = 4;
// 初始化邻接矩阵
int adj_matrix[n][n] = { {0, 1, 0, 1},
{1, 0, 1, 0},
{0, 1, 0, 1},
{1, 0, 1, 0} };
// 打印邻接矩阵
for(int i=0; i<n; i++) {
for(int j=0; j<n; j++) {
cout << adj_matrix[i][j] << " ";
}
cout << endl;
}
return 0;
}
```
在这个示例中,我们创建了一个大小为 4 的图,并初始化了其邻接矩阵。最后,我们打印了邻接矩阵以进行验证。你可以根据自己的需要修改图的大小和邻接矩阵。
相关问题
邻接矩阵的c++代码实现
邻接矩阵是一种常见的图数据结构,它用二维数组表示图中每个顶点之间的连接关系。下面是一个简单的C++代码实现,假设我们有一个无向图:
```cpp
#include <iostream>
#include <vector>
// 定义一个无向图节点
struct Node {
int id;
};
// 定义邻接矩阵
class AdjacencyMatrix {
private:
std::vector<std::vector<int>> matrix; // 图的大小和边的值
public:
// 构造函数,初始化一个n x n的全零矩阵
AdjacencyMatrix(int n) : matrix(n, std::vector<int>(n, 0)) {}
// 添加边 (u, v),如果(u, v)之间有边,则置对应位置为1
void addEdge(int u, int v) {
matrix[u][v] = 1;
matrix[v][u] = 1; // 对于无向图,需要两边都记录
}
// 检查是否包含边 (u, v)
bool isConnected(int u, int v) const {
return matrix[u][v] == 1;
}
};
int main() {
AdjacencyMatrix graph(5); // 创建一个有5个顶点的图
graph.addEdge(0, 1);
graph.addEdge(1, 2);
graph.addEdge(3, 4);
// 输出连接情况
for (int i = 0; i < graph.matrix.size(); ++i) {
for (int j = i; j < graph.matrix[i].size(); ++j) {
if (graph.isConnected(i, j)) {
std::cout << "Edge between node " << i << " and " << j << ": Connected\n";
} else {
std::cout << "Edge between node " << i << " and " << j << ": Not connected\n";
}
}
}
return 0;
}
```
图的表示—邻接矩阵练习c++代码不用函数
在C++中,我们可以使用二维数组(邻接矩阵)来表示图的数据结构,特别是无向图。如果你想要创建一个邻接矩阵并手动处理添加和访问边的操作,你可以这样做:
```cpp
#include <iostream>
using namespace std;
const int MAX_VERTEX = 10; // 假设最多有10个顶点
// 邻接矩阵,值为0表示没有连接,1表示有连接
int adjMatrix[MAX_VERTEX][MAX_VERTEX] = {0};
void addEdge(int src, int dest) {
// 添加边到邻接矩阵,注意矩阵是行主序的
adjMatrix[src][dest] = 1;
adjMatrix[dest][src] = 1; // 对于无向图,需要双向标记
}
bool isConnected(int vertex1, int vertex2) {
return adjMatrix[vertex1][vertex2] != 0; // 检查两个顶点之间是否有边
}
int main() {
int numVertices, numEdges;
cout << "Enter number of vertices: ";
cin >> numVertices;
cout << "Enter number of edges: ";
cin >> numEdges;
cout << "Enter edges (source destination): " << endl;
for (int i = 0; i < numEdges; ++i) {
int src, dest;
cin >> src >> dest;
addEdge(src, dest);
}
int vertex1, vertex2;
cout << "Check connectivity between two vertices (enter -1 to exit):" << endl;
while (cin >> vertex1 && vertex1 != -1) {
cout << "Vertex 2: ";
cin >> vertex2;
if (isConnected(vertex1, vertex2)) {
cout << "Connected.\n";
} else {
cout << "Not connected.\n";
}
}
return 0;
}
```
在这个例子中,我们首先定义了一个邻接矩阵`adjMatrix`来存储图的信息。然后通过`addEdge`函数添加边,`isConnected`函数用于检查两点是否相连。用户可以在`main`函数中输入节点和边的信息以及查询连接情况。
阅读全文