【图论】详解链式前向星存图法+遍历法

细说链式前向星存图法

首先要明白,链式前向星的原理是利用存边来进行模拟图。

推荐左神的视频--建图、链式前向星、拓扑排序

比方说有这样一张图,我们用链式前向星来进行模拟时,可以将每一条边都进行编号,其中,红色 的数字就是对每一条边的编号蓝色 的数字表示每一个结点编号

准备三个数组head[], next[], to[]

数组名称 下标含义 值的含义
head 结点值 结点指向的初边
next 边的编号 该边指向下一条边
to 边的编号 边指向的结点值

idx:表示当前还没有分配的边编号

添加边

所以添加边的函数add()可以这样去设计:

c 复制代码
//建立一个a->b的结点->结点,->表示边
inline void add(int a, int b) {
	to[idx] = b, next[idx] = head[a], head[a] = idx++;
}
//新建一条边,编号为idx,指向结点b,然后在a结点的邻居边中增加idx边,思想类似与头插法,让这个新的边指向头边,并修改头边为新的边。

Code

c 复制代码
#include <iostream>
#include <cstring>
using namespace std;

const int N = 10001;				//最多生成N个结点,N-1个单边
int head[N], to[N], next[N], idx;

// head[]头边号 
// 点号 

// next[] 下一条边号 
// 边号

// to[] 去往的点
// 边号

// idx 
inline void add(int a, int b) {
	to[idx] = b, next[idx] = head[a], head[a] = idx++;
}

inline void dfs(int u) {
	cout << u << ' ';
	int i = head[u];		//i为u结点第一条边
	for (; i != -1; i = next[i]) {
		//每次更新为下一条边
		dfs(to[i]); 		//去到 i 边指向的结点 
	}
}

int main() {
	memset(head, -1, sizeof head);//head[i]为-1表示这个结点没有后继边
	add(1, 2);
	add(1, 5);
	add(1, 6);
	add(2, 6);
	add(5, 6);
	dfs(1);
}
相关推荐
Zero2 小时前
机器学习微积分--(1)核心思想
人工智能·算法·机器学习
有Li2 小时前
一种病理学内容感知变速率学习图像压缩框架 (PathoLIC)/文献速递-多模态应用技术
人工智能·深度学习·算法·计算机视觉·医学生
x_xbx2 小时前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
Ricky_Theseus2 小时前
数据库关系代数 - 连接操作
linux·数据库·算法
绿算技术2 小时前
宝辰股份董事长莅临绿算技术调研交流
人工智能·科技·算法
码云数智-园园3 小时前
哈希冲突的解决之道:深入理解哈希表底层原理
算法·哈希算法
qq_416018723 小时前
C++中的模板方法模式
开发语言·c++·算法
天上路人3 小时前
A-59F 多功能语音处理模组在本地会议系统扩音啸叫处理中的技术应用与性能分析
人工智能·神经网络·算法·硬件架构·音视频·语音识别·实时音视频
yang_B6214 小时前
噪声处理方法
大数据·人工智能·算法
菜菜小狗的学习笔记4 小时前
剑指Offer算法题(九)搜索
数据结构·算法·深度优先