当前位置: 首页 > news >正文

【数据结构与算法】图的存储(邻接矩阵,邻接表)详解

图的邻接矩阵数据结构

typedef enum { NDG, DG, NDN, DN } GraphKind;using VRType = int;
using InfoType = int;typedef struct ArcCell {VRType adj;InfoType *info;
} Arc[N][N];struct MGraph {ElemType vexs[N];Arc arc;int vexnum, arcnum;GraphKind kind;
};

ArcCell 结构体包含两个成员:

  • adj 是一个 VRType 类型的变量,表示顶点之间的关系,例如,如果两个顶点之间存在边,那么 adj 表示这条边的权重。
  • info 是一个指向 InfoType 类型的指针,用于存储与边相关的额外信息。

MGraph 结构体包含四个成员:

  • vexs 是一个 ElemType 类型的数组,用于存储图的顶点。
  • arc 是一个 Arc 类型的二维数组,用于存储图的边。
  • vexnum 是一个整数,表示图的顶点数量。
  • arcnum 是一个整数,表示图的边数量。
  • kind 是一个 GraphKind 类型的枚举,表示图的类型。

图的数组表示法、邻接表存贮结构各自的优缺点,适应的运算。

  1. 图的数组表示法(邻接矩阵):

    • 优点:容易实现图的操作,如:求某顶点的度、判断顶点之间是否有边(弧)、找顶点的邻接点等等。
    • 缺点:n个顶点需要n*n个单元存储边(弧);空间效率为 O ( n 2 ) O(n^2) O(n2)。 对稀疏图而言尤其浪费空间。
    • 适应的运算:边的数量较多,需要频繁检查节点间是否存在边的场景。
  2. 图的邻接表存储结构:

    • 优点:n个顶点、e条边的无向图,只需要n个头结点和2e个表结点。对稀疏图而言,比数组表示法节省存储空间。
    • 缺点:每条边需要对应两个表结点。
    • 适应的运算:边的数量较少,需要频繁添加或删除边的场景。
http://www.lryc.cn/news/380268.html

相关文章:

  • 【深度C++】之“类与结构体”
  • CTO的职责是什么?
  • 【GD32】从零开始学兆易创新32位微处理器——RTC实时时钟+日历例程
  • HTTP网络协议
  • Kubernetes相关生态
  • C语言入门4-函数和程序结构
  • 分行业二氧化碳排放数据
  • 【OS基础】符合AUTOSAR标准的RTAOS-Alarms详解
  • 基于Java的学生成绩管理系统
  • 都2024年了,还有人不懂动态代理么?
  • ARM功耗管理框架之PPU
  • 说说 SSL 的错误认识和不足之处
  • Go语言day1
  • 【Python机器学习】利用t-SNE进行流形学习
  • 03 - matlab m_map地学绘图工具基础函数 - 设置坐标系(m_coord)
  • UEC++ 虚幻5第三人称射击游戏(一)
  • java小代码(1)
  • SLAM ORB-SLAM2(27)词袋模型
  • OpenAI 的 GPT-5:CTO米拉-穆拉提说,到 2026 年将实现博士级智能(Ph.D.-Level))
  • macbook配置adb环境和用adb操作安卓手机
  • 微软TTS最新模型,发布9种更真实的AI语音
  • python爬虫 -爬取 json 格式数据
  • Pytorch(5)-----梯度计算
  • C#的膨胀之路:创新还是灭亡
  • SpringBoot 过滤器和拦截器的区别
  • 协程执行顺序引发的问题
  • android webview调用js滚动到指定位置
  • WPF 深入理解一、基础知识介绍
  • 腾讯云点播ugc upload | lack signature 问题处理
  • 计算机视觉实验二:基于支持向量机和随机森林的分类(Part one: 编程实现基于支持向量机的人脸识别分类 )