C++ 数据结构(三)列表(1)接口与实现

本文探讨了从静态数据结构到动态数据结构的转变,重点关注C++中的列表。文章阐述了列表作为动态存储策略的例子,其节点通过指针或引用形成线性序列。相对于向量的循秩访问,列表更倾向于使用位置访问。文章还介绍了列表节点的抽象数据类型(ADT)接口,以及ListNode模板类和List模板类的设计。
摘要由CSDN通过智能技术生成

来源:我的博客站 OceanicKang |《C++ 数据结构(三)列表(1)接口与实现》

上一篇:《C++ 数据结构(二)向量(8)归并排序》

从静态到动态

根据是否修改数据结构,所有操作大致分为两类方式:

1、静态:仅读取,数据结构的内容及组成一般不变,如 getsearch

2、动态:需写入,数据结构的局部或整体将改变,如 insertremove

与操作方式相对应的,数据元素的存储与组织方式也分为两种:

1、静态

  • 数据空间整体创建或销毁
  • 数据元素的物理存储次序与其逻辑次序严格一致
  • 可支持高效的静态操作
  • 比如向量,元素的物理地址与其逻辑次序线性对应

2、动态

  • 为各数据元素动态分配和回收物理空间
  • 逻辑上相邻的元素记录彼此的物理地址,在逻辑上形成一个整体
  • 可支持高效的动态操作

从向量到列表

列表(list)是采用动态储存策略的典型结构

其中的元素称作节点(node)

各节点通过指针或引用彼此联接,在逻辑上构成一个线性序列

$ L = { a_0, a_1, \cdots , a_{n-1} } $

向量节点彼此互称前驱(predecessor)或后继(successor)

前驱或后继若存在,则必然唯一

没有前驱/后继的唯一节点称作(first/front)/(last/rear)节点

1.png

从秩到位置

向量支持循秩访问(call-by-rank)的方式

根据数据元素的秩,可在 O(1) 时间内直接确定其物理地址

V[i] 的物理地址 = V + i * s,s 为单个单元占用的空间量

既然同属线性序列,列表固然也可通过秩来定位节点:从头/尾端出发,沿后继/前驱引用 …

然而,此时的循秩访问成本过高,已不合时宜

因此,应改用循位置访问(call-by-position)的方式

亦即,应转而利用节点之间的相互引用,找到特定的节点

2.png

列表节点:ADT 接口

作为列表的基本元素,列表节点首先需要独立的“封装”实现

为此,可设置并约定若干基本的操作接口

操作 功能
pred() 当前节点前驱节点的位置
succ()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值