首页 > 后端开发 > C++ > 正文

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

裘德小鎮的故事
发布: 2025-09-28 20:47:01
原创
532人浏览过
使用vector实现邻接表是C++中表示图的常用方法,适合稀疏图。1. 基本结构为vector<vector<int>>,每个顶点对应一个存储邻接点的动态数组;2. 无向图每条边在两个顶点中各存一次,有向图只在起点存储;3. 带权图使用vector<vector<pair<int, int>>>,存储邻接点和权重;4. 初始化时指定顶点数并合理添加边,避免越界;5. vector相比list内存连续、缓存友好,遍历效率高,适用于DFS、BFS等算法。

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

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

邻接表的基本结构

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

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

基本实现步骤

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

爱图表
爱图表

AI驱动的智能化图表创作平台

爱图表 99
查看详情 爱图表

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

#include <iostream>
#include <vector>
using namespace std;

class Graph {
private:
    int V; // 顶点数量
    vector<vector<int>> 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<pair<int, int>>,其中第一个值是邻接点,第二个是权重。

class WeightedGraph {
private:
    int V;
    vector<vector<pair<int, int>>> 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等。

以上就是c++++中如何实现图的邻接表_c++图邻接表实现方法的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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