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

数组模拟邻接表 #图论

文章目录

  • 为什么要用数组来模拟邻接表
  • 存储思路
  • 遍历思路

树是特殊的图,因此邻接表可以存储图和树两种数据结构。

为什么要用数组来模拟邻接表

在算法设计当中,利用数组来代替结构体模拟各种数据结构会更加简单。

存储思路

给定如下数据,我们可以构造如下的一个邻接表
在这里插入图片描述
在这里插入图片描述
请看代码

/**
	idx:索引,代表数组哪个位置,是否连续不重要,
	因为我们的存储是链式的。
	
	h[idx] : 顶点表,下标idx代表是哪个顶点,初始值全部为-1,代表没有数据
	e[idx] : 边表,下标idx存储的边值 
	ne[idx] :  索引为idx的下一个索引
	
	其中a是顶点,b是边表。即a指向b
	
	如果其是一个无向图,那么我们可以建立a指向b和b指向a。
	如果其实一个树,那么a代表父节点,b代表孩子节点
**/
void add(int a,int b){
	e[idx]=b;
	ne[idx]=h[a];
	h[a]=idx++;
}

在这里插入图片描述

遍历思路

下面演示遍历1号头结点

for(int i=h[1]; i!=-1; i=ne[i]){
	int j=e[i];//当前边的值
	cout<<j; 
} 



http://www.kler.cn/a/595936.html

相关文章:

  • DeepBI:重构流量逻辑,助力亚马逊广告实现高效流量增长
  • 算法竞赛备赛——【数据结构】链表
  • 村民信息管理系统
  • WRF移动嵌套结合伏羲模型与CFD(PALM)高精度多尺度降尺度分析研究
  • 回顾一下-笔记
  • Ubuntu启动不了Terminal
  • 高级java每日一道面试题-2025年3月07日-微服务篇[Eureka篇]-Eureka Server和Eureka Client关系?
  • 挂谷问题与挂谷猜想:从平面转针到高维拓扑
  • STM32学习笔记之常用总线(原理篇)
  • OpenCV图像处理基础2
  • 补充--HTTP常见的状态码
  • Neo4j GDS(Graph Data Science)库安装(Mac版)
  • HTML 图像与多媒体元素:拓展学习边界的进度记录(二)
  • 【C++进阶】深入探索类型转换
  • uniapp自定义导航头,页面内容自动盛满禁止滚动效果
  • DigitalFoto公司如何用日事清流程管理工具实现任务优先级与状态可视化?
  • 平衡树的模拟实现
  • cursor常用快捷键(JetBrains Darcula主题风格)
  • 【赵渝强老师】达梦数据库MPP集群的架构
  • 记录瞬间:面试中的技术碰撞与思考