图的存储结构(哈喜老师版本)

1、邻接矩阵

1.1:邻接矩阵的概念

1.2:用邻接矩阵存储图对应的代码

cpp 复制代码
#define Max_Vertex_Num 20    //定义最大顶点数量
typedef char VertexType;
typedef int EdgeType;
typedef struct{
    int vexnum,arcnum;           //图中的顶点数和边数
    VertexType vexs[Max_Vertex_Num]; //存放顶点中的值
    EdgeType edges[Max_Vertex_Num][Max_Vertex_Num]; // 邻接矩阵
}MGraph; // 图的结构

1.3:通过邻接矩阵求顶点的度

1.4:通过邻接矩阵判断两个顶点之间是否有边

1.5 习题

习题1(易)

2.邻接表

2.1:邻接表的概念

2.2:通过邻接表求顶点的度

2.3:用邻接表存储图对应的代码(难)

cpp 复制代码
// 边结点
typedef struct ArcNode {
    int adjvex;              // 邻接点的下标(顶点编号)
    struct ArcNode *nextarc; // 指向下一条边的指针
} ArcNode;

// 顶点结构(邻接表头结点)
typedef struct ArcNode {
    int adjvex;              // 邻接点的下标(顶点编号)
    ArcNode *nextarc; // 指向下一条边的指针
} ArcNode,AdjList[MaxVertexNum];
// 表示可以用AdjList定义一个长度为MaxVertexNum,每个元素的类型为struct ArcNode类型的数组。
// 即AdjList a等价于struct ArcNode a[MaxVertexNum]

// 邻接表表示的图
typedef struct {
    AdjList a;//等价于struct ArcNode a[MaxVertexNum]   // 顶点数组
    int vexnum, arcnum;   // 顶点数、边数
} ALGraph;

3.邻接表和邻接矩阵的对比

4.邻接多重表 (非重点)

5.十字链表 (非重点)

相关推荐
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠2 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾2 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8212 天前
算法复键——树状数组
数据结构·算法
酉鬼女又兒2 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php
牛油果子哥q2 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒2 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记2 天前
单项不带头不循环链表
数据结构·链表
小糯米6013 天前
JS 数组
数据结构·算法·排序算法
小欣加油3 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展