线性表的类型定义

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

例2-2 已知一个非纯集合B,试构造一个纯 集合A,使A中只包含B中所有值各不相同 的数据元素。
void purge(List &La, List Lb) {
// 已知线性表Lb中的数据元素依值非递减 有序排列(Lb是有序表),
// 构造线性表La,使其只包含Lb中所有值 不相同的数据元素
InitList(LA); La_len = ListLength(La); Lb_len =ListLength(Lb); // 求线性表的长度 for (i = 1; i <= Lb_len; i++) { GetElem(Lb, i, e); // 取Lb中第i个数据元素赋给e if(!equal (en, e)) { //en初始化为LB中没有的值 ListInsert(La, ++La_len, e); en = e; } // La中不存在和 e 相同的数据元素,则插入之 } } // purge
1≤i≤LengthList(L) 操作结果:删除L的第i个元素,并用e返回
其值,L的长度减1。
} ADT List
利用上述定义的线性表可以完成其它 更复杂的操作
例2-1 假设有两个集合A和B分别用两个 线性表LA和LB表示(即:线性表中的数 据元素即为集合中的成员),现要求一 个新的集合A=A∪B。
一个,则用pre_e 返回它的 前驱,否则操作失败,pre_e无定义。
NextElem( L, cur_e, &next_e ) 初始条件:线性表L已存在。 操作结果:若cur_e是L的元素,但不是最
后一个,则用next_e返回它 的后继,否则操作失败,next_e无定义。
GetElem( L, cur_e, &next_e ) 初始条件:线性表L已存在,
i=2,...,n } {设线性表为 (a1,a2,...,ai,...,an), 称i为
ai在线性表中的位序。}
基本操作:
{结构初始化} InitList( &L ) 操作结果:构造一个空的线性表L。 {销毁结构} DestroyList( &L ) 初始条件:线性表L已存在。 操作结果:销毁线性表L。
线性表的类型定义
线性结构是一个数据元素的有序(次序) 集
在数据元素的非空有限集中
线性 存在唯一的一个被称作“第一个”的数据元 结构 素
存在唯一的一个被称作“最后一个”的数据
特点: 元素
除第一个外,集合中的每个数据元素均只有 一个前驱
除最后一个外,集合中的每个数据元素均只 有一个后继
2.1 线性表的类型定义:
ai的直接后继是ai+1,an无直接 后继
元素同构,且不能出现缺项
线性表是一种典型的线性结构。
抽象数据类型线性表的定义如 下:
ADT List { 数据对象:D={ ai | ai ∈ElemSet,
i=1,2,...,n, n≥0 } {称n为线性表的表长; 称n=0时的线性表为空
表。} 数据关系:R1={ <ai-1 ,ai >|ai-1 ,ai∈D,
1≤i≤LengthList(L) 操作结果:L中第i个元素赋值同e的值。
ListInsert( &L, i, e ) 初始条件:线性表L已存在,
1≤i≤LengthList(L)+1 操作结果:在L的第i个元素之前插入新的
元素e,L的长度增1。
ListDelete(&L, i, &e) 初始条件:线性表L已存在且非空,
3.若不存在,则插入之。 ListInsert(LA, n+1, e)
void union(List &La, List Lb) { // 将所有在线性表Lb中但不在La中的数据元素插
入到La中 La_len = ListLength(La); Lb_len =ListLength(Lb); // 求线性表的长度 for (i = 1; i <= Lb_len; i++) { GetElem(Lb, i, e); // 取Lb中第i个数据元素赋给e if(!LocateElem(La, e, equal( )) ListInsert(La, ++La_len1, e); // La中不存在和 e 相同的数据元素,则插入之 } } // union
上述问题可演绎为,要求对线性表作如下 操作:扩大线性表LA,将存在于线性表 LB中而不存在于线性表LA中的数据元素 插入到线性表LA中去。
思路:
1.从线性表LB中依次取得每个数据元素; GetElem(LB, i)→e
2.依次在线性表LA中进行查访; LocateElem(LA, e, equal( ))
1≤i≤LengthList(L) 操作结果:用e返回L中第i个元素的值。
LocateElem( L, e, compare( ) ) 初始条件:线性表L已存在,compare( )是
元素判定函数。
操作结果:返回L中第1个与e满足关系 compare( )的元素的位序。
若这样的元素不存在,则返回值为0。
{引用型操作}
ListEmpty( L ) 初始条件:线性表L已存在。 操作结果:若L为空表,则返回TRUE,否
则FALSE。 ListLength( L ) 初始条件:线性表L已存在。 操作结果:返回L中元素个数。
PriorElem( L, cur_e, &pre_e ) 初始条件:线性表L已存在。 操作结果:若cur_e是L的元素,但不是第
ListTraverse(L, visit( )) 初始条件:线性表L已存在。 操作结果:依次对L的每个元素调用函数
visit( )。一旦visit( )失败,则操 作失败。
{加工型操作}
ClearList( &L ) 初始条件:线性表L已存在。 操作结果:将L重置为空表。 PutElem( L, i, &e ) 初始条件:线性表L已存在,
定义: 一个线性表是n个数据元素的有限序列
如 a1 , a2, , ai , an
例 英文字母表(A,B,C,…..Z)是一个线性表
例 学号
姓名
001
张三
Baidu Nhomakorabea
002
李四
……
……
年龄
数据元素
18
19
……
特征:
元素个数n—表长度,n=0空表 1<i<n时
ai的直接前驱是ai-1,a1无直接前 驱
相关文档
最新文档