3第三章线性表分解.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构 第三章 线性表 计算机科学系 施化吉 E-mail: hjshi002@163.com;第三章 线性表;第三章 线性表; ? 3.1.2.线性表(a1,a2,a3, ……an)的逻辑特征: (1)有且仅有一个开始结点a1(无直接前趋); (2)有且仅有一个终端结点an(无直接后继); (3)其余的结点ai都有且仅有一个直接前趋ai-1和一个直接后继ai+1。; ; ? 3.1.4.线性表的基本操作 初始化: 设定一个空的线性表L。 求长度: 求线性表L中数据元素的个数len。 (3)?取元素: 取线性表L中序号为i的数据元素,若1≤i≤len,则函数值为线性表L中第i个数据元素,否则为NULL。 (4)?定位: 给定值item,若线性表L中有数据元素等于item,则返回该数据元素的序号,若有多个数据元素等于item,则返回最小的序号,若无数据元素等于item,则返回0。;(5)插入: 在线性表L的第i个数据元素之前插入一个新元素item,这里1≤i≤len+1,当i = len+1时,即在线性表L的表尾插入(即追加)新元素,插入成功返回1,不成功返回0。 (6)删除: 删除线性表L的第i个元素。当1≤i≤len时,删除成功,返回被删元素的值,否则返回NULL。 (7)是否为空表: 线性表L为空,则返回值1,否则返回值0。 (8)表清空: 将线性表L设置为空表,即len = 0。 对线性表的操作还有很多,像取前驱、取后继、排序等等。;3.2 线性表的顺序表示;3.2.0 顺序表的定义、存储和特点;? 2.顺序表中数据元素的存储地址 若每个数据元素占用m个存储单元,则 第i个数据元素的存储位置为: Loc(a i)=Loc(a 1)+(i-1)*m Loc(a 1)称为基地址(第一个数据元素的存储位置)。 显然,数据元素在顺序表中位置取决于数据元素在线性表中的位置i。 顺序表的特点是:;任意两个逻辑上相邻的数据元素在物理上也必然相邻。 顺序表中的每个表项都是单个数据元素,所有表项的数据类型相同。 顺序表可以“随机”访问。;3.2.1?? 顺序表的类定义; get 输入:表的序号i 前置条件:序号i大于或等于1,并且小于或等于表的长度 动作:取序号为i的数据元素 输出:如果是合法序号,则返回表的第i个数据元素; 否则,返回NULL。 后置条件:无 locate 输入:要定位的项item 前置条件:无 动作:在表中查找item 输出:如果找到,则返回item在表中的位置; 否则返回0 后置条件:无;insert 输入: 要插入的项item和序号i 前置条件:表未满,并且i未越界 动作: 在序号i处插入项item 输出: 若插入成功返回1;否则输出0 后置条件:表中增加了一个新元素,长度加1 delete 输入: 序号i 前置条件:表非空,并且i未越界 动作: 删除序号为i的数据元素 输出:若删除成功,则返回被删元素的值; 否则返 回 NULL 后置条件:表中减少了一个元素,长度减1; empty 输入: 无 前置条件:无 动作: 检查表的长度 输出: 表为空时返回1,否则返回0 后置条件:无 clear 输入: 无 前置条件:无 动作: 清空顺序表 输出: 无 后置条件:表的长度是0 end ADT seqlist; ? 2.顺序表的类定义 一个顺序表涉及的数据成员包括数组、数组所允许的最多元素的个数和当前数据元素的个数,它们被封装在类的私有域中。 //以下内容定义在头文件seq

文档评论(0)

1112111 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档