图的存储结构——十字链表的理解

2024-02-21 02:40

本文主要是介绍图的存储结构——十字链表的理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7.2 图的存储结构

  • 7.2.4十字链表 Orthogonal List
    • 十字链表的存储结构
      • 十字链表的顶点结点结构
      • 十字链表的弧结点结构
      • 十字链表的存储结构

7.2.4十字链表 Orthogonal List

同无向图类似,有向图也有另外一种链式存储结构称为十字链表。
根据应用的需要,对于有向图有时既需要用邻接表,又需要用逆邻接表,这时可以把两个表合二为一,用有向图的邻接多重表(通常称为十字链表)表示。

十字链表的存储结构

在这里插入图片描述

十字链表的顶点结点结构

对有向图中的每一个顶点也用一个顶点结点表示,它由三个域组成,其中:
data域存储有关顶点的信息:firstinarc域是链接指针,指向第一条以该顶点为终点的弧;
firstoutarc域也是链接指针,指向第一条以该顶点为始点的弧。
所有的顶点结点组成一个顺序表。

十字链表的弧结点结构

在有向图的十字链表中,图中的每一条弧用一个弧结点表示。
弧结点的结构与无向图邻接多重表中的边结点结构类似,也有六个域。
其中:
tag是标记域,标记该弧是否被处理或被搜索过;
weight为弧的信息域,用于存储弧的权值等信息;
tailvex和headvex是分别表示弧尾顶点序号和弧头顶点序号的顶点域;
tailnextarc域是链接指针,指向下一条以顶点tailvex为始点(弧尾)的弧;
headnextarc也是链接指针,指向下一条以顶点headvex为终点(弧头)的弧。
在这里插入图片描述

十字链表的存储结构

在这里插入图片描述
在有向图的十字链表中,从顶点结点中的firstoutarc域出发,由弧结点中的tailnextarc域链接起来的链表,正好是原来的邻接表结构。统计该链表中弧结点的个数,可求得该顶点的出度。若从顶点结点的 firstoutarc域出发,由弧结点中的headnextarc域链接起来的链表,正好是原来的逆邻接表结构。统计该链表中弧结点的个数,可求得该顶点的入度。

其 实现 可以参考:
https://blog.csdn.net/majiakun1/article/details/88692940

这篇关于图的存储结构——十字链表的理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/730338

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

Redis高性能Key-Value存储与缓存利器常见解决方案

《Redis高性能Key-Value存储与缓存利器常见解决方案》Redis是高性能内存Key-Value存储系统,支持丰富数据类型与持久化方案(RDB/AOF),本文给大家介绍Redis高性能Key-... 目录Redis:高性能Key-Value存储与缓存利器什么是Redis?为什么选择Redis?Red

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

使用SpringBoot+InfluxDB实现高效数据存储与查询

《使用SpringBoot+InfluxDB实现高效数据存储与查询》InfluxDB是一个开源的时间序列数据库,特别适合处理带有时间戳的监控数据、指标数据等,下面详细介绍如何在SpringBoot项目... 目录1、项目介绍2、 InfluxDB 介绍3、Spring Boot 配置 InfluxDB4、I

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录