0

0

c++ 图的邻接表表示 c++图数据结构实现

冰火之心

冰火之心

发布时间:2025-11-28 12:45:06

|

1031人浏览过

|

来源于php中文网

原创

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

c++ 图的邻接表表示 c++图数据结构实现

在C++中实现图的邻接表表示,是一种高效且常用的方式,尤其适合稀疏图(边数远小于顶点数平方)的存储和操作。邻接表使用数组或vector配合链表(或vector)来存储每个顶点的邻接顶点,既能节省空间,又能方便地遍历邻居节点。

邻接表的基本结构

一个无向图或有向图可以用以下方式建模:

  • 用一个vector> 来表示每个顶点连接的其他顶点。
  • 如果是带权图,可以用 vectorair>>,其中 pair 的第一个值是邻接点,第二个是边的权重。
  • 顶点编号通常从0或1开始。

基础实现:无向无权图

// graph_adjacency_list.cpp

#include iostream>
#include
using namespace std;

class Graph {
private:
    int V; // 顶点数量
    vector> adj; // 邻接表

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,数据一站式更新,支持微信支付与支付宝支付接口,是专业的网上商城系统,网趣商城系统支持淘宝数据包导入,实现与淘宝同步更新!支持上传图片水印设置、图片批量上传功能,同时支持订单二次编辑以及多级分类隐藏等实用功能,新版增加商品大图浏览与列表显示功能,使分类浏览更方便,支持最新的支付宝即时到帐接口。

下载

立即学习C++免费学习笔记(深入)”;

class WeightedGraph {
private:
    int V;
    vector>> adj; // 邻接表:目标顶点,权重

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         }
    }

};

关键点说明

  • 使用 vector> 是最常见做法,动态扩容,代码简洁。
  • 对于稀疏图,邻接表比邻接矩阵更节省内存。
  • 遍历某个顶点的所有邻居时间复杂度为 O(度),效率高。
  • 若频繁查询两点是否有边,可考虑搭配哈希表优化,但一般DFS/BFS不需要。
  • 支持快速插入边,删除边稍麻烦(需在vector中erase),如需频繁删除可用 list 替代 inner vector。
基本上就这些。这种实现方式灵活、直观,是算法题和实际开发中图结构的标准写法之一。

相关专题

更多
edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1300

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

375

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

878

2025.04.24

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.09.27

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

521

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

187

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

PHP 表单处理与文件上传安全实战
PHP 表单处理与文件上传安全实战

本专题聚焦 PHP 在表单处理与文件上传场景中的实战与安全问题,系统讲解表单数据获取与校验、XSS 与 CSRF 防护、文件类型与大小限制、上传目录安全配置、恶意文件识别以及常见安全漏洞的防范策略。通过贴近真实业务的案例,帮助学习者掌握 安全、规范地处理用户输入与文件上传的完整开发流程。

1

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.5万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号