网站大量收购闲置独家精品文档,联系QQ:2885784924

第 5 数组和广义表.pptVIP

  1. 1、本文档共80页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第 5 数组和广义表

第5章 数组和广义表 本章目录 5.1 数组的定义及其基本操作 5.1.1 数组 5.1.2 数组的逻辑定义 5.2 数组的顺序存储 5.3 矩阵的压缩存储 5.3.1 特殊矩阵 5.3.2 稀疏矩阵 5.4 广义表 5.4.1 广义表的定义 5.4.2 广义表的存储结构 *5.5算法设计举例 知识点和难点重点 知识点 基本概念:数组、稀疏矩阵、广义表 数组地址计算 特殊矩阵 广义表 难点重点 特殊矩阵,存储公式 广义表的存储及算法 数组 数组逻辑上是线性结构的推广; 数组是以元素为线性表的线性结构,而且元素的结构相同; 数组可以看作是下标和值的偶对的集合; 数组是一种逻辑结构。 自测题 1 数组是同类型值的集合。( ) 【上海海运学院 1996 一.3(1分) 1999 一.4(1分)】 × 高级语言中的数组 int a[10]; char B[4][5] 二维数组 int a[2][3]; 二维数组可以看成是元素为一维数组的一维数组。 a[0],a[1]都是数组的名字,也就是地址。 数组的逻辑定义 n维数组的元素个数 自测题 2 从逻辑结构上看,n维数组的每个元素均属于n个向量。( ) 【东南大学 2001 一.2 (1分)】 【中山大学 1994 一.2 (2分)】 √ 数组的抽象数据类型 ADT Array{ 数据对象:ji=0,…,bi-1,i=1,2,…,n, D={aj1j2…,jn|n(0)称为数组的维数, bi是数组第i维的长度,ji是第i维的下标, aj1j2…jn ElemSet} 数据关系:R={R1,R2,…,Rn} 基本操作: ArrayInit(A,n,bound1..boundn) ArrayValue(A,index1,…,indexn) ArrayAssign(A,e,index1,…,indexn) }ADT Array 数组的操作 数组一般不做插入和删除操作 对于数组的操作一般只有两类: (1) 给定一组下标,存取相应的数据元素 (2) 给定一组下标,修改相应的数据元素的值。 自测题 3 数组可看成线性结构的一种推广,因此与线性表一样,可以对它进行插入,删除等操作。( ) 【上海交通大学 1998 一.5(1分)】 × 自测题 4 数组通常具有的两种基本操作是() A.查找和修改 B. 查找和索引 C.索引和修改 D. 建立和删除 【中南大学2005一.10(2分)】 A 顺序存储时按行序和列序的约定 数组顺序存储时,必须确定按行序或列序存储: (1) PASCAL、C 以行序为主存储 (2)FORTRAN 以列序为主存储 数组的顺序存储 自测题 5 若6行5列的数组以列序为主序顺序存储,基地址为1000,每个元素占2个存储单元,则第3行第4列的元素(假定无第0行第0列)的地址是( )。 A. 1040 B. 1042 C. 1026 D. 备选答案A,B,C都不对 【华中科技大学2004一.4(1分)】 A n维数组的元素的存储位置 三维数组的表示 42、( 13 分)设将n(n1)个整数存放到一维数组R中。试设计一个在时间和空间两方面都尽可能高效的算法,将R中保存的序列循环左移P(0Pn)个位置, 即将R中的数据由(X0,X1,…,Xn-1)变换为(Xp,Xp+1,…,Xn-1,X0,X1,…,Xp-1)。要求: (1)给出算法的基本设计思想。 (2)根据设计思想,采用C 或C++或JAVA 语言描述算法,关键之处给出注释。 (3)说明你所设计算法的时间复杂度和空间复杂度。 【2010年全国硕士研究生入学统一考试计算机学科专业基础综合】 (1) 算法设计思想:按照下标0到p-1、p到n-1、0到n-1的顺序,将这三段分别逆置,最后的结果即为所求。 (3) 算法执行了两趟逆置,时间复杂度为O(n);用了一个辅助变量空间,空间复杂度为O(1)。 讨论:若采用直接左移p位,空间复杂度仍为O(1),但时间复杂度为O(np)。 (2) void leftshift(

文档评论(0)

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

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

1亿VIP精品文档

相关文档