链式前向星(最通俗易懂的讲解)

链式前向新:用于存储图的 边集 数组

前言

当我们存储图的时候,往往会使用 邻接矩阵 或是 邻接表。

邻接矩阵 好写,但太浪费空间,节点一多就存不下;

邻接表 效率高,但涉及指 ,不好写容易出错;用 vector 又可能超时。

链式前向星 就是一个相对中庸的存储方式,虽然说,链式前向星 使用并不广泛,但在需要使用复杂 邻接表 时,这就是一个较好的选择。

链式前向星 其实就是 静态建立的邻接表,时间复杂度为O(m),空间复杂度也为O(m)。


思想

对于下图:

图1

输入为:

5 7

1 2 3

2 3 1

1 3 4

1 5 3

4 1 5

4 5 1

3 4 2

我们将起点都是 from 的边串在一起,用 head[from] 存储头节点(见图2,下图为最终形式)

图2

具体插入操作与链表相似 (见图3)

图3


代码与运行结果

里有注释,慢慢理解

cpp 复制代码
#include <iostream>
#include <cstring>

using namespace std;

const int N = 2e2 + 5, M = 1e3 + 5;

int n, m, cnt; //n个点,m条边
struct Edge {
	int to, value, next;
	//终点,边权,同起点的上一条边的编号
} edge[M]; //边集
int head[N]; //head[i] 表示以 i 为起点的第一条边在边集数组的位置(编号)

void add_edge(int from, int to, int value) { //u起点,v终点,w边权
	edge[++ cnt] = {to, value, head[from]}, head[from] = cnt;
	// 赋终点权值 并且将新的节点赋在头上	更新头
}

int main() {
	cin >> n >> m;

	/* 初始化 */
	cnt = 0;
	memset(head, -1, sizeof head);

	/* 加边 */
	for (int i = 1; i <= m; i ++) { //输入m条边
		int a, b, c;
		cin >> a >> b >> c;
		add_edge(a, b, c);
	}

	/* 遍历 */
	for (int i = 1; i <= n; i ++) {
		cout << ">" << i << "\n";
		bool hase = false;
		for (int j = head[i]; j != -1; j = edge[j].next) //遍历以i为起点的边
			cout << i << " " << edge[j].to << " " << edge[j].value << "\n", hase = true;
		if (!hase)
			cout << "nothing\n"; //第i个节点没有出去的边
	}
	return 0;
}
/*
5 7
1 2 3
2 3 1
1 3 4
1 5 3
4 1 5
4 5 1
3 4 2
*/

可以注意到 head 的初始值为 -1

这使得 head[i] 中第一个边的 next 为 -1,这正作为链的结尾(见图3

所以当 访问指针 ( j ) 为 -1 时,就代表访问结束了

运行结果参考

图4

(从 图2~4 和 代码中,我们都可以发现 链式前向星 是按输入倒着存的)


结语

个人觉得 链式前向星 和 邻接表 是几乎一样的,只不过 前者 是静态的,后者 是动态的

相关推荐
千金裘换酒1 天前
Leetcode 有效括号 栈
算法·leetcode·职场和发展
空空潍1 天前
hot100-最小覆盖字串(day12)
数据结构·算法·leetcode
Rui_Freely1 天前
Vins-Fusion之 相机—IMU在线标定(十一)
人工智能·算法·计算机视觉
yyy(十一月限定版)1 天前
算法——二分
数据结构·算法
七点半7701 天前
c++基本内容
开发语言·c++·算法
嵌入式进阶行者1 天前
【算法】基于滑动窗口的区间问题求解算法与实例:华为OD机考双机位A卷 - 最长的顺子
开发语言·c++·算法
嵌入式进阶行者1 天前
【算法】用三种解法解决字符串替换问题的实例:华为OD机考双机位A卷 - 密码解密
c++·算法·华为od
罗湖老棍子1 天前
信使(msner)(信息学奥赛一本通- P1376)四种做法
算法·图论·dijkstra·spfa·floyd·最短路算法
生成论实验室1 天前
生成论之基:“阴阳”作为元规则的重构与证成——基于《易经》与《道德经》的古典重诠与现代显象
人工智能·科技·神经网络·算法·架构
啊董dong1 天前
noi-2026年1月07号作业
数据结构·c++·算法·noi