邻接表用vector存储无向图,addEdge双向添加边,print遍历输出;带权图用vector存边权,适合稀疏图,空间省、遍历快。

在C++中实现图的邻接表表示,是一种高效且常用的方式,尤其适合稀疏图(边数远小于顶点数平方)的存储和操作。邻接表使用数组或vector配合链表(或vector)来存储每个顶点的邻接顶点,既能节省空间,又能方便地遍历邻居节点。
一个无向图或有向图可以用以下方式建模:
#include iostream>
#include
using namespace std;
class Graph {
private:
int V; // 顶点数量
vector
public:
Graph(int vertices) : V(vertices), adj(vertices) {}
// 添加边(无向图)
void addEdge(int u, int v) {
adj[u].push_back(v);
adj[v].push_back(u); // 无向图双向添加
}
// 打印邻接表
void print() const {
for (int i = 0; i
cout
for (int neighbor : adj[i]) {
cout
}
cout
}
}
};
// 使用示例
int main() {
Graph g(5); // 创建5个顶点的图
g.addEdge(0, 1);
g.addEdge(0, 4);
g.addEdge(1, 2);
g.addEdge(1, 3);
g.addEdge(1, 4);
g.addEdge(2, 3);
g.addEdge(3, 4);
g.print();
return 0;
}
如果需要处理有向图或带权图,可以修改邻接表为存储 pair 或自定义结构体。
网趣网上购物系统支持PC电脑版+手机版+APP,数据一站式更新,支持微信支付与支付宝支付接口,是专业的网上商城系统,网趣商城系统支持淘宝数据包导入,实现与淘宝同步更新!支持上传图片水印设置、图片批量上传功能,同时支持订单二次编辑以及多级分类隐藏等实用功能,新版增加商品大图浏览与列表显示功能,使分类浏览更方便,支持最新的支付宝即时到帐接口。
0
立即学习“C++免费学习笔记(深入)”;
class WeightedGraph {
private:
int V;
vector
public:
WeightedGraph(int vertices) : V(vertices), adj(vertices) {}
// 添加有向边 u -> v,权重 w
void addEdge(int u, int v, int w) {
adj[u].push_back({v, w});
}
void print() const {
for (int i = 0; i
cout
for (auto& edge : adj[i]) {
cout
}
cout
}
}
};
以上就是c++++ 图的邻接表表示 c++图数据结构实现的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号