数据结构学习笔记——线性表

摘要:
在这种情况下,数据元素通常用作记录,包含大量记录的线性表用作文件。线性表中的数据元素可以是各种各样的,但同一线性表中元素必须具有相同的特征,即它们属于同一数据对象,并且相邻元素之间存在顺序对关系。线性表是一种相当灵活的数据结构,它的长度可以根据需要增加或缩短,也就是说,线性表的数据元素不仅可以被访问,还可以被插入和删除。

第2章  线性表

2.1  线性表的类型定义 

线性结构的特点是:在数据元素的非空有限集中,(1)存在唯一的一个被称做“第一个”的数据元素;(2)存在唯一的一个被称做“最后一个”的数据元素;(3)除第一个之外,集合中的每个数据元素只有一个前驱;(4)除最后一个外,集合中每个数据元素均只有一个后继。

线性表的类型定义

线性表(linear_list)是最常用的且最简单的一种数据结构。一个线性表是n个数据元素的有限序列。在稍复杂的线性表中,一个数据元素可以由若干个数据项(item)组成。在这种情况下,常把数据数据元素成为记录(record),含有大量记录的线性表成为文件(file)

线性表中的数据元素可以是各种各样的,但同一线性表中的元素必定是具有相同特性,即属同一数据对象,相邻元素之间存在着序偶关系。

若将线性表记为

    (a1,···,ai-1,ai,ai+1,···,an)

则表中ai-1领先于ai,ai领先于ai+1,称ai-1是ai的直接前驱元素,ai+1是ai的直接后继元素。当i=1,2,···,n-1是时,ai有且仅有一个直接后继,当i=2,3,···,n时,ai有且仅有一个直接直接前驱。

线性表中元素的个数n(n>=0)定义为线性表的长度,n=0时称为空表。在非空表中的每个数据元素都有一个确定的位置,如a1是第一个数据元素,an是最后一个数据元素,ai是第i个数据元素,称i为数据元素ai在线性表中的位序。

线性表是一个相当灵活的数据结构,它的长度可根据需要增长或缩短,即对线性表的数据元素不仅可以进行访问还可以进行插入和删除等。

线性表的基本操作:

1、InitList(&L)

  操作结果:构造一个空的线性表L。

2、DestroyList(&L)

  初始条件:线性表L已存在

  操作结果:销毁线性表L

3、ClearList(&L)

  初始条件:线性表L已存在

  操作结果:将线性表L重置为空表

4、ListEmpty(&L)

  初始条件:线性表L已存在

  操作结果:判断线性表是否为空表,若线性表L为空表则返回TRUE,否则返回FALSE

5、ListLength(L)

  初始条件:线性表L已存在

  操作结果:返回线性表中数据元素的个数,即求表长

6、GetElem(L,i,&e)

  初始条件:线性表L已存在,1<=i<=ListLength(L)

  操作结果:用e返回线性表L中第i个数据元素的值

7、LocateElem(L,e,compare())

  初始条件:线性表L已存在,compare()是数据元素判定函数

  操作结果:返回星星变L中第1个与e满足关系compare()的数据元素的位序。若这样的数据元素不存在,则返回值为0

8、PriorElem(L,cur_e,&pre_e)

  初始条件:线性表L已存在

  操作结果:若cur_e是线性表L的数据元素,且不是第1个,则用pre_e返回它的前驱,否则造作失败,pre_e无定义

9、NextElem(L,cur_e,&next_e)

  初始条件:线性表L已存在

  操作结果:若cur_e是线性表L的数据元素,且不是最后一个,则用next_e返回它的后继,否则操作失败,next_e无定义

10、ListInsert(&L,i,e)

  初始条件:线性表L已存在,1<=i<=ListLength(L)+1

  操作结果:在线性表L中第i个位置之前插入新的数据元素e,线性表L的长度加1

11、ListDelete(&L,i,&e)

  初始条件:线性表L已存在且非空,1<=i<=ListLength(L)

  操作结果:删除线性表L中的第i个数据元素,并用e返回其值,线性表L的长度减1

12、ListTraverse(L,visit())

  初始条件:线性表L已存在

  操作结果:依次对线性表L的每个数据元素调用函数visit()。一旦visit()失败,则操作失败。

免责声明:文章转载自《数据结构学习笔记——线性表》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Oracle快速测试连接是否成功Ubuntu 14.04 FTP服务器--vsftpd的安装和配置下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Win32多线程编程(1) — 基础概念篇

  内核对象的基本概念 Windows系统是非开源的,它提供给我们的接口是用户模式的,即User-Mode API。当我们调用某个API时,需要从用户模式切换到内核模式的I/O System Services API。例如我们调用Kernel32.dll中的CreateFile创建文件,最终将执行ntdll.dll中的系统服务NtCreateFile...

数据结构-链表习题

判断题 1.在单向链表中,头指针中存放的是头结点的内容。      T      F 2.单向链表中的每个结点都需要动态分配内存空间。      T      F 3.通常使用结构的嵌套来定义单向链表结点的数据类型。      T      F 4.用链表代替数组进行数据操作时,查询更加方便。      T      F 选择题 1.以下程序的输...

redis基础数据结构源码浅析

基于redis 5.0.6 先列个表格 类型 实现 string sds list quicklist set intset hashtable zset ziplist skiplist+hashtable hash ziplist hashtable string redis的string(字符串)实现称为SDS(...

数据结构笔记五:树与二叉树

目录 树 树的基本概念 树的性质 树的存储结构 双亲表示法(顺序存储) 孩子表示法(顺序+链式) 孩子兄弟表示法 树、森林的遍历 树的先根遍历 树的后根遍历 树的层次遍历 森林的先序遍历 森林的中序遍历 总结 二叉树 二叉树的基本概念 几种特殊的二叉树 二叉树的性质 二叉树的存储结构 顺序存储 链式存储 遍历算法 先序遍历...

C++的标准模板库STL中实现的数据结构之顺序表vector的分析与使用

摘要本文主要借助对C++的标准模板库STL中实现的数据结构的学习和使用来加深对数据结构的理解,即联系数据结构的理论分析和具体的应用实现(STL),本文是系列总结的第一篇,主要针对线性表中的顺序表(动态数组)STL vector进行分析和总结。 引言由于前段时间对台大的机器学习基石和技法课程进行了学习,发现在具体的实现中常常涉及到各种类型的数据结构,比...

golang数据结构之双链表

目录结构:  doubleLink.go package link import ( "fmt" ) //HerosNode 链表节点 type HerosNode struct { ID int Name string pre *HerosNode //指针 next *HerosNode //指针 }...