【数据结构】十字链表的画法

十字链表的基本概念

  • 有向边又称为弧

  • 假设顶点 v 指向 w,那么 w 称为弧头,v 称为弧尾

  • 顶点节点采用顺序存储

  • 顶点节点

    • data:存放顶点的信息
    • firstin:指向以该节点为终点(弧头)的弧节点
    • firstout:指向以该节点为起点(弧尾)的弧节点
  • 弧节点

    • tailvex:起点(弧尾)在数组中的索引
    • headvex:终点(弧头)在数组中的索引
    • hlink:终点(弧头)相同的下一个弧节点
    • tlink:起点(弧尾)相同的下一个弧节点
    • info:存放边(弧)有关的信息

画法

示例

第 1 步

  • 先画顶点节点,并在右侧标出顶点对应的索引
  • 右侧的这些索引就叫它第 i 列吧, i ∈ [ 0 , 3 ] i \in [0, 3] i∈[0,3]

第 2 步

  • 遍历每个顶点,找到该顶点指向的其他顶点 i,从左到右画弧节点,弧节点的位置对应第 i 列,每一行最右侧弧节点的 tlink 置为空
  • 如果索引为 i 的顶点节点没有出度,那么 firstout 置为空

第 3 步

  • 索引为 i 的顶点节点的 firstin 指向第 i 列的第一个节点(从上到下的第一个弧节点
  • 如果第 i 列一个节点也没有,那么 firstin 置为空

第 4 步

  • 遍历每一列,将 hlink 按列从上到下进行连接
  • 每一列最后一个弧节点的 hlink 置为空(从上到下,最上面的是第一个,最下面的是最后一个
相关推荐
高山有多高3 小时前
顺序表:数据结构中的基础线性存储结构
数据结构
默默无名的大学生3 小时前
数据结构——链表的基本操作
数据结构·算法
_OP_CHEN3 小时前
数据结构(C语言篇):(十一)二叉树概念介绍
c语言·开发语言·数据结构·二叉树·学习笔记··
Neverfadeaway3 小时前
C语言————冒泡排序(例题2)
c语言·数据结构·算法·冒泡排序·升序排列·降序排列
散1123 小时前
01数据结构-B树
数据结构·b树
亦良Cool3 小时前
001-Pandas的数据结构
数据结构·pandas
nsjqj4 小时前
数据结构中的 二叉树
数据结构
初学小白...4 小时前
红黑树-数据结构
数据结构
captain3764 小时前
qqq数据结构补充
数据结构
知彼解己5 小时前
【算法】四大基础数据结构
数据结构·算法