开发者社区> 华章计算机> 正文

《数据结构与算法 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;

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【408数据结构与算法】—栈的抽象数据类型定义(十)
由于栈本身就是线性表,于是栈也有顺序存储和链式存储两种实现方式
8 0
【408数据结构与算法】—顺序表的定义(三)
顺序表:用顺序存储的方式实现线性表
8 0
【408数据结构与算法】—线性表的定义和分析(二)
线性表的定义:线性表示具有相同数据类型的n(n>=0)个数据元素的有限序列,其中n为表长,当n=0 时,线性表是一个空表,若用L命名线性表,则一般表示为:L=(a1,a2,……,ai,an)
10 0
C语言|数据结构——线性结构(线性表及其实现)
线性表(Linear List)主要操作的实现 初始化广义表实际上就是多重链表 多重链表中的结点可能同时隶属多个链 指针域会有多个,例如上面代码行中的Next和SubList两个指针域 但双向链表中包含两个指针域,并不是多重链表基本上树、图这样相对复杂的数据结构都可以采用多重链表方式实现存储。 矩阵 采用典型的多重链表——十字链表来代替二维数组来存储稀疏矩阵 (二维数组存储稀疏矩阵缺点:1.会造成大量空间浪费
31 0
C语言实现线性表
C语言实现线性表
21 0
数据结构(C语言版)之线性表(下)
前言 ●数据结构作为计算机专业基础课,综合性强,抽象性高,在一定程度上增加了学习难度,本次我们共同从数据结构的基础探讨,由浅入深进行数据结构的学习。  ●本文只浅显的探讨了链表的基本知识,作者相信随着学习课程的深入,我们将会对数据结构有更深的理解与收获! ●由于作者水平有限,文章难免存在谬误之处,敬请读者斧正,俚语成篇,恳望指教!
42 0
数据结构(C语言版)之线性表(上)
前言 ●数据结构作为计算机专业基础课,综合性强,抽象性高,在一定程度上增加了学习难度,本次我们共同从数据结构的基础探讨,由浅入深进行数据结构的学习。  ●本文只浅显的探讨了顺序表的基本知识,后续会进行链表的知识探讨。作者相信随着学习课程的深入,我们将会在对数据结构有更深的理解与收获! ●由于作者水平有限,文章难免存在谬误之处,敬请读者斧正,俚语成篇,恳望指教!
55 0
《数据结构》c语言版学习笔记——其他链表(线性表的链式存储结构Part2)
《数据结构》c语言版学习笔记——其他链表(线性表的链式存储结构Part2)
46 0
《数据结构》c语言版学习笔记——线性表的顺序存储结构
《数据结构》c语言版学习笔记——线性表的顺序存储结构
63 0
文章
问答
来源圈子
更多
+ 订阅
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载