《数据结构与算法 C语言版》—— 2.1线性表的定义

简介:

本节书摘来自华章出版社《数据结构与算法 C语言版》一 书中的第2章,第2.1节,作者:徐凤生,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.1线性表的定义

2.1.1线性表的概念

线性表是一种线性结构。简言之,一个线性表是由n个数据元素构成的有限序列。线性表中的数据元素可以是一个数或一个字符,也可以是由若干数据项组成的记录,甚至可以是更复杂的信息。也就是说,线性表中的数据元素可以是任意类型的,但必须是相同类型的。
通常将n个数据元素构成的线性表记为:(a1,a2,…,ai-1,ai,ai+1,…,an)。其中,n称为线性表的表长,当n=0时称为空表。线性表中的数据元素之间存在着顺序关系,其中ai-1是ai的前驱,ai是ai-1的后继(i=2,3,…,n),i称为数据元素ai在线性表中的位序。
在实际应用中,线性表的例子是很多的。例如,26个字母组成的字母表:
(A,B,…,Z)

是一个线性表,其中的数据元素是单个字母。又如学生信息表,如表2.1所示。其中每个数据元素是由姓名、学号、性别、年龄、班级等数据项组成的记录。
screenshot

2.1.2线性表的抽象数据类型定义

抽象数据类型是指一个数据结构及其上的一组操作。数据结构的操作是定义在逻辑结构层次上的,而操作的具体实现是建立在存储结构上的,因此线性表的基本操作作为逻辑结构的一部分定义在抽象数据类型中,每个操作的具体实现只有在确定了线性表的存储结构之后才能完成。线性表的长度可以根据需要增长或缩短,即对线性表的数据元素不仅可以进行访问,还可以进行插入和删除等。
线性表的抽象数据类型定义如下:

ADT List{
数据对象:D={ai|ai∈ElemSet,i=1,2, …,n,n≥0}
数据关系:R1={|ai-1,ai∈D,i=2,…,n}
基本操作:
InitList(&L)
初始条件:线性表L不存在。
操作结果:构造一个空的线性表L。
CreateList(&L)
初始条件:线性表L为空表。
操作结果:建立一个含有n个元素的线性表L。
ListEmpty(L)
初始条件:线性表L已存在。
操作结果:若L为空表,则返回TRUE,否则返回FALSE。
ListLength(L)
初始条件:线性表L已存在。
操作结果:返回L中元素的个数。
GetElem(L,i,&e)
初始条件:线性表L已存在,且1≤i≤ListLength(L)。
操作结果:用e返回L中第i个元素的值。
LocateElem(L,e)
初始条件:线性表L已存在,e为给定值。
操作结果:返回L中指向元素值为e的第1个结点的指针。若这样的元素不存在,则返回空指针。
DispList(L)
初始条件:线性表L已存在。
操作结果:依次输出L中的每个元素。
DestroyList(&L)
初始条件:线性表L已存在。
操作结果:销毁线性表L。
ListInsert(&L,i,e)
初始条件:线性表L已存在,且1≤i≤LengthList(L)+1。
操作结果:在L的第i个元素之前插入新的元素e,L的长度增1。
ListDelete(&L,i,&e)
初始条件:线性表L已存在且非空,1≤i≤LengthList(L)。
操作结果:删除L的第i个元素,并用e返回其值,L的长度减1。
}ADT List

需要指出的是,以上线性表的抽象数据类型定义中的操作不是它的全部,只是一些常用的基本操作。可以利用上述基本操作实现其他更复杂的操作。这些基本操作要在确定了存储结构之后才能实现。
为了讨论方便,如无特别说明,本章假定ElemType为int类型,使用如下自定义类型语句定义:

typedef int ElemType;

相关文章
|
6月前
|
人工智能 算法 搜索推荐
电商API的“AI革命”:全球万亿市场如何被算法重新定义?
AI+电商API正引领智能商业变革,通过智能推荐、动态定价与自动化运营三大核心场景,大幅提升转化率、利润率与用户体验。2025年,75%电商API将具备个性化能力,90%业务实现智能决策,AI与API的深度融合将成为未来电商竞争的关键基石。
|
存储 算法 测试技术
【C++数据结构——线性表】求集合的并、交和差运算(头歌实践教学平台习题)【合集】
本任务要求编写程序求两个集合的并集、交集和差集。主要内容包括: 1. **单链表表示集合**:使用单链表存储集合元素,确保元素唯一且无序。 2. **求并集**:遍历两个集合,将所有不同元素加入新链表。 3. **求交集**:遍历集合A,检查元素是否在集合B中存在,若存在则加入结果链表。 4. **求差集**:遍历集合A,检查元素是否不在集合B中,若满足条件则加入结果链表。 通过C++代码实现上述操作,并提供测试用例验证结果。测试输入为两个集合的元素,输出为有序集合A、B,以及它们的并集、交集和差集。 示例测试输入: ``` a c e f a b d e h i ``` 预期输出:
386 7
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
580 5
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】顺序表的基本运算(头歌实践教学平台习题)【合集】
本文档介绍了线性表的基本运算任务,涵盖顺序表和链表的初始化、销毁、判定是否为空、求长度、输出、查找元素、插入和删除元素等内容。通过C++代码示例详细展示了每一步骤的具体实现方法,并提供了测试说明和通关代码。 主要内容包括: - **任务描述**:实现顺序表的基本运算。 - **相关知识**:介绍线性表的基本概念及操作,如初始化、销毁、判定是否为空表等。 - **具体操作**:详述顺序表和链表的初始化、求长度、输出、查找、插入和删除元素的方法,并附有代码示例。 - **测试说明**:提供测试输入和预期输出,确保代码正确性。 - **通关代码**:给出完整的C++代码实现,帮助完成任务。 文档
415 5
|
存储 Java
数据结构第二篇【关于java线性表(顺序表)的基本操作】
数据结构第二篇【关于java线性表(顺序表)的基本操作】
186 6
|
存储
【数据结构】线性表和顺序表
【数据结构】线性表和顺序表
156 1
|
算法 安全 搜索推荐
2024重生之回溯数据结构与算法系列学习之王道第2.3章节之线性表精题汇总二(5)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
IKU达人之数据结构与算法系列学习×单双链表精题详解、数据结构、C++、排序算法、java 、动态规划 你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
人工智能 算法 前端开发
无界批发零售定义及无界AI算法,打破传统壁垒,累积数据流量
“无界批发与零售”是一种结合了批发与零售的商业模式,通过后端逻辑、数据库设计和前端用户界面实现。该模式支持用户注册、登录、商品管理、订单处理、批发与零售功能,并根据用户行为计算信用等级,确保交易安全与高效。
01(数据结构考研)线性表相关操作代码
01(数据结构考研)线性表相关操作代码
206 0
|
存储 C语言
数据结构之线性表的初始化及其操作
数据结构之线性表的初始化及其操作
248 0