0

0

c++中如何实现图的邻接表_c++图邻接表实现方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-09-28 20:47:01

|

562人浏览过

|

来源于php中文网

原创

使用vector实现邻接表是C++中表示图的常用方法,适合稀疏图。1. 基本结构为vector,每个顶点对应一个存储邻接点的动态数组;2. 无向图每条边在两个顶点中各存一次,有向图只在起点存储;3. 带权图使用vector,存储邻接点和权重;4. 初始化时指定顶点数并合理添加边,避免越界;5. vector相比list内存连续、缓存友好,遍历效率高,适用于DFS、BFS等算法。

c++中如何实现图的邻接表_c++图邻接表实现方法

在C++中实现图的邻接表,通常使用标准模板库(STL)中的vectorlist来存储每个顶点的邻接顶点。这种方式灵活、高效,适合稀疏图的表示。

邻接表的基本结构

邻接表本质上是一个数组(或vector),其中每个元素对应一个顶点,并保存与该顶点相连的所有边的信息。对于无向图,每条边会在两个顶点中各出现一次;对于有向图,只在起点处记录。

常用的数据结构是:vector>vector>。现代C++开发中更推荐使用vector,因为其内存连续、缓存友好。

基本实现步骤

以下是构建一个无向图的邻接表表示的完整示例:

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载

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

#include 
#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 printGraph() {
        for (int i = 0; i < V; ++i) {
            cout << "顶点 " << i << ": ";
            for (int neighbor : adj[i]) {
                cout << neighbor << " ";
            }
            cout << endl;
        }
    }
};

// 使用示例
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.printGraph();
    return 0;
}

带权图的邻接表实现

如果图是带权的,就不能只存邻接顶点,还需要存储对应的边权。可以使用vector>,其中第一个值是邻接点,第二个是权重。

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

public:
    WeightedGraph(int vertices) : V(vertices), adj(vertices) {}

    void addEdge(int u, int v, int weight) {
        adj[u].push_back({v, weight});
        adj[v].push_back({u, weight}); // 无向图,有向图则省略
    }

    void printGraph() {
        for (int i = 0; i < V; ++i) {
            cout << "顶点 " << i << ": ";
            for (auto& edge : adj[i]) {
                cout << "(" << edge.first << "," << edge.second << ") ";
            }
            cout << endl;
        }
    }
};

常见注意事项

实现邻接表时需注意以下几点:

  • 初始化时确保vector大小正确,避免越界访问
  • 添加边时检查顶点编号是否在有效范围内
  • 若频繁删除边,可考虑使用list替代vector
  • 对于大规模图,注意内存使用和遍历效率
基本上就这些。用vector实现邻接表简单直观,适合大多数图算法场景,比如DFS、BFS、Dijkstra等。

相关专题

更多
string转int
string转int

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

312

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

522

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

190

2025.08.29

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

7

2025.12.22

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

389

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

44

2025.12.31

热门下载

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

精品课程

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

共94课时 | 5.8万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.7万人学习

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

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