干货分享|图论的常见存储方式之链式前向星

链式前向星

示意图

链式前向星的代码非常模板话,但是在初学截断单看代码很难理解其中的原理。

下面着重对第 1 步和第 4 步的建图进行阐述:设为 0。

选取最近未使用的边的空间,此时边号 idx=02 有一条权值为 3 的边。

选取最近未使用的边的空间,此时边号idx=0

在 idx=0 处存储入度点 2 和权值 3

将 idx=0 处 nex 位置存为 head[0]=-1

将 head[0] 更新为当前的边号 idx=0

第 4 步[0, 3, 5] 表示 0 到 3 有一条权值为 5 的边。

选取最近未使用的边的空间,此时边号 idx = 3

在 idx=3 处存储入度点 2 和权值 3

将 idx=3 处 nex 位置存为head[0]=0 (注意,这是第 1 步时,存储的值)

将 head[0] 更新为当前的边号 idx=3

由于 head 数组始终指向最后存储的位置。因此在遍历 head[from] 时,与存储的顺序时相反的。(而邻接表在遍历时与存储顺序一致)

聪明的读者应该已经发现了,其实链式前向星就是另一种表现形式的邻接表。

数据结构

复制代码
struct Edge {
    int to;     // 入度点
    int val;    // 权值
    int nex;    // 下一个节点
};

Edge edge[边数];
int head[点数];
int tot = 0; // 使用到了第几条边

操作

复制代码
// 添加边
void addEdge(int from, int to, int value) {
    // 根据tot的初始值确定使用的第一条边的边号
    tot += 1;
    edge[tot].to = to;
    edge[tot].val = value;
    edge[tot].nex = head[from];
    head[from] = tot;
}

// 遍历
for (int i = head[from]; /*根据head初始值作为终止条件*/; i = edge[i].nex) {
    int to = edge[i].to;
    int val = edge[i].val;
}
相关推荐
EllinY14 分钟前
CF2217E Definitely Larger 题解
c++·笔记·算法·构造
玖釉-3 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法
IronMurphy3 小时前
【算法五十】62. 不同路径
算法
影寂ldy4 小时前
C#一维数组
算法
过期动态4 小时前
【LeetCode 热题 100】移动零
java·数据结构·算法·leetcode·职场和发展·rabbitmq
计算机安禾5 小时前
【算法分析与设计】第10篇:下界理论与NP完全性初步
大数据·人工智能·算法
水木流年追梦6 小时前
大模型入门-大模型分布式训练2
开发语言·分布式·python·算法·正则表达式·prompt
sali-tec6 小时前
C# 基于OpenCv的视觉工作流-章78-KRT测量
图像处理·人工智能·数码相机·opencv·算法·计算机视觉
菜菜的顾清寒6 小时前
力扣HOT100(32)二叉树的中序遍历
数据结构·算法·leetcode