第2章线性表--顺序表示与实现.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2.2 线性表的顺序表示和实现 一、 顺序表的存储结构表示 1、顺序表:用一组地址连续的存储单元依次存储线性表的各个数据元素。即采用顺序存储结构的线性表。它通常采用静态数组实现数据元素的存储。 (1) 逻辑上相邻的数据元素,其物理上也相邻; (2) 若已知表中首元素在存储器中的位置,则其他元素存放位置亦可求出(利用数组V[n]的下标)。 设有一维数组M,下标的范围是0到9,每个数组元素用相邻的5个字节存储。存储器按字节编址,设存储数组元素M[0]的第一个字节的地址是98,则M[3]的第一个字节的地址是多少? 4、用C语言描述 typedef struct { DateType list[MaxSize]; int size; }SeqList; /* MaxSize表示数组的最大元素个数,list表示顺序表的数组名,size表示顺序表中当前存储的数据元素个数,它必须满足size≤ MaxSize,SeqList是该结构体的名字。*/ 二、 顺序表的实现(或操作) 实现步骤: 将第i+1 至第n 位的元素向前移动一个位置; 表长减1。 注意:事先需要判断,删除位置i 是否合法? 三、 顺序表操作的效率分析 算法时间主要耗费在移动元素的操作上,因此 计算时间复杂度的基本操作(最深层语句频度) T(n)= O (移动元素次数) 而移动元素的个数取决于插入或删除元素的位置. 教材P33有对执行效率的推导:(与课本略有区别) 作业: P55 2-1, 2-2, 2-11,2-15 * * 一 、顺序表的存储结构 二、 顺序表的实现 三、 顺序表的运算效率分析 可以利用数组V[n]来实现 注意:在C语言中数组的下标是从0开始,即: V[n]的有效范围是从 V[0]~V[n-1] 设首元素a0的存放地址为LOC(a0)(称为首地址), 设每个元素占用存储空间(地址长度)为L字节, 则表中任一数据元素的存放地址为: LOC ( ai+1 ) = LOC( ai ) + L LOC ( ai ) = LOC( a0 ) + L *i 对上述公式的解释如图所示 2、线性表顺序存储特点: an-1 …… ai+1 ai …… a1 a0 地址 内容 元素在表中的位序 0 i 1 n-1 空闲区 i+1 L b=LOC(a0) b + L b +iL b +(n-1)L b +(MaxSize-1)L LOC ( ai ) = LOC( a0 ) + L *i 3、线性表的顺序存储结构示意图 113 LOC( M[3] ) = 98 + 5 ×3 =113 解:已知地址计算通式为: LOC(ai) = LOC(a0) + L *i 例1 ? char V[30]; void build() /*字母线性表的生成,即建表操作*/ { int i; V[0]=a; for( i=1; i=n-1; i++ ) V[i]=V[i-1]+1; } 核心语句: 方法1 V[i]= V[i-1]+1; 方法2 V[i]=’a’+i; 方法3 V[i]=97+i; 例2   用数组V来存放26个英文字母组成的线性表(a,b,c,…,z),写出在顺序结构上生成和显示该表的C语言程序。 void main(void) /*主函数,字母线性表的生成和输出*/ { n=26; /* n是表长,是数据元素的个数,而不是V的 实际下标*/ build( ); display( ); } void display( ) /*字母线性表的显示,即读表操作*/ { int i; for( i=0; i=n-1; i++ ) printf( %c, v[i] ); printf( \n ); } 执行结果: a b c d e f g h i j k l m n o p q r s t u v w x y z 数据结构的基本运算: 修改、插入、删除、查找、排序 1) 修改 通过数组的下标便可访问某个特定元素并修改之。 核心语句: V[i]=x; 显然,顺序表修改操作的时间效率是 O(1) 在线性表(n个元素)的第i个位置前插入一个元素 实现步骤: 将第n至第i 位的元素向后移动一个位置; 将要插入的元素写到第i个位置; 表长加1。 注

文档评论(0)

jdy261842 + 关注
实名认证
文档贡献者

分享好文档!

1亿VIP精品文档

相关文档