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

数据结构——第二章 线性表(8)——线性表总结

线性表总结

线性表是线性结构的基本形式,用于描述一组同类型而具有1:1线性关系的数据对象。将此类数据对象存放在计算机的内存中时,必须考虑数据元素的存放和数据元素之间关系的存放。常用的存储结构有顺序存结构和链式结构。

顺序表存储特点是用一维数组存放线性表中的数据元素,用下标的相邻关系表示数据元素的直接前驱和直接后继关系。为了方便使用,经常需要用到表中数据元素的个数以及是否存在剩余空间,能够满足上述要求的变量类型是结构体类型。由于C语言没有给出此种结构体类型的定义,因此必须自定义该类型,即顺序表类型。本书给出了两种顺序表类型的定义,并进行了对比分析。第一种容易掌握,但是由于在类型中直接给出了数组的大小,因此通用性和灵活性较差。第二种在类型中给出的是存放一维数组首地址的指针成员,数组的大小由初始化操作完成,大大提高了该类型的实用性。

如果数据元素的类型是简单类型,则顺序表类型的自定义只需一步,直接定义顺序表结构体类型即可。如果数据元素的类型是结构体类型是结构体类型,则顺序表类型的自定可分两步完成。
(1)先定义数据元素对应的结构体类型。
(2)再定义顺序表结构体类型。

链式存储结构的特点是用一个带头结点的单向链表存放线性表的数据元素。其存储空间遵循“按需分配”,根据需要动态申请结点空间,不需要是可释放结点的存储空间。线性表中数据元素的关系用结点中存放后继结点地址的指针变量表示。链表对内存空间的连续性要求较低,每个数据元素占用的存储空间比顺序表中占用的空间要大。

如果数据元素的类型是简单类型,链表类型的自定义只需一步,直接定义结点类型和指向结点的指针类型即可。如果数据元素的类型是结构体类型,链表类型的自定义可分两步完成。
(1)先定义数据元素对应的结构体类型。
(2)再定义链表的结点类型和指向结点的指针类型。

链表有多种形式,除了单向链表外,还有单向循环链表和双向循环链表。
基于这两种存储结构的基本操作实现,需根据每个基本操作是否改变了存储结构中的成员值以及需要的其他条件,正确定义函数的形参。熟练掌握基本操作之后,对于其他复杂的操作,只需对基本操作进行组合或修改某些基本操作即可。

http://www.lryc.cn/news/20730.html

相关文章:

  • 3.7寸按键翻页工牌
  • 西北工业大学大学物理(II)选填解析2019-2020期末
  • [计算机网络(第八版)]第一章 概述(章节测试/章节作业)
  • 华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典
  • 电子科技大学数据库与软件工程三
  • 华为开源自研AI框架昇思MindSpore数据变换:Transforms
  • 软件测试之边界值测试法
  • 【华为OD机试模拟题】用 C++ 实现 - 最近的点(2023.Q1)
  • Qt windeployqt.exe 打包qml
  • 【人脸识别】CurricularFace:自适应课程学习人脸识别损失函数
  • springmvc之rest风格(RESTFUL)
  • django项目实战十四(django+bootstrap实现增删改查)进阶混合数据使用modelform上传
  • 2023年CDGA考试模拟题库(1-100)
  • HTML常用基础内容总结
  • Gorm-学习笔记
  • 【Neo4j】图数据库CypherQueryLanguage随笔
  • STM32Cube串口USART发送接收数据
  • OpenFeign详解
  • python多线程网络编程
  • BFS-走迷宫
  • 【蓝牙mesh】Lower协议层介绍
  • Java-重排序,happens-before 和 as-if-serial 语义
  • Nginx安装及介绍
  • 【华为OD机试模拟题】用 C++ 实现 - 寻找路径 or 数组二叉树(2023.Q1)
  • LINUX学习记录
  • 华为OD机试用Python实现 -【狼羊过河 or 羊、狼、农夫过河】(2023-Q1 新题)
  • 【SAP Abap】X-DOC:SAP ABAP 语法更新之Open SQL
  • leetcode 困难 —— 数组中的逆序对(分治法)
  • 02.24:图片的风格转换
  • [SSD综述 1.3] SSD及固态存储技术半个世纪发展史