第五章 数组及广义表.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文档。上传文档
查看更多
第五章 数组及广义表.ppt

作业 设任意n个整数存放于数组A 1:n 中,试编写算法,将所有正数排在所有负数前面。 本题属于排序问题,只是排出正负,不排出大小。可在数组首尾设两个指针i和j,i自小至大搜索到负数停止,j自大至小搜索到正数停止。然后i和j所指数据交换,继续以上过程,直到 i j为止。 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Definition 广义表又称列表,是n n ? 0 个元素的有限序列,记作A a1, a2, …, an 。其中A是列表的名字,n是它的长度,ai可以是数据元素,也可以是列表。如果ai是列表,则称其为列表A的子表。 什么是广义表? * 习惯上,用大写字母表示列表的名称,用小写字母表示数据元素。用圆括号把列表的元素括起来,用逗号分隔开列表中的元素。 广义表的类型定义 ADT Glist 数据对象:D= ei | i 1,2,..,n; n≥0; ei∈AtomSet 或 ei∈GList, AtomSet为某个数据对象 数据关系: LR= ei-1, ei | ei-1 ,ei∈D, 2≤i≤n ADT Glist 基本操作: 广义表是递归定义的线性结构, LS ?1, ?2, ???, ?n 其中:?i 或为原子 或为广义表 例如: A F d, e D a, b,c , F C A, D, F B a, B a, a, a, ??? , 广义表是一个多层次的线性结构 例如: D E, F 其中: E a, b, c F d, e D E F a d b c e * 列表的深度 列表展开后的最大括号层次数。 例如: L a, b, c 列表L长度为3,深度为1 E E为空表,长度为0,深度为1 A x, L, z 列表A的长度为3,深度为2 B A, y, E 列表B的长度为3,深度为3 C A, B 列表C的长度为2,深度为4 D z, D 列表D的长度为2,深度为无穷大 相关概念 * L a, b, c 列表L长度为3,深度为1 E E为空表,长度为0,深度为1 A x, L, z 列表A的长度为3,深度为2 B A, y, E 列表B的长度为3,深度为3 C A, B 列表C的长度为2,深度为4 D z, D 列表D的长度为2,深度为无穷大 再入表:允许结点共享的表,如列表C。 递归表:允许递归的表,如列表D。 * 列表可以用图形象地表示 在图中,列表是非终端结点(即交叉结点),数据元素是终端结点,空表作为一个特殊的终端结点。 L a, b, c A x, L, z L a b c x A z L a b c * B A, y, E E y x A z L a b c B 纯表:通常把与树对应的列表称为纯表,它限制了表中成分的共享性和递归。例如列表L、A、B。 * C A, B E y x A z L a b c B C D z, D D z 可知,具有共享和递归特性的列表可以和有向图建立对应。 广义表 LS ?1, ?2, …, ?n 的结构特点: 1 广义表中的数据元素有相对次序; 2 广义表的长度定义为最外层包含元素个数; 3 广义表的深度定义为所含括弧的重数; 注意:“原子”的深度为 0 “空表”的深度为 1 4 广义表可以共享; 5 广义表可以是一个递归的表。 递归表的深度是无穷值,长度是有限值。 6 任何一个非空广义表 LS ?1, ?2, …, ?n 均可分解为 表头 Head LS ?1 和 表尾 Tail LS ?2, …, ?n 两部分。 例如: D E, F a, b, c ,F Head D E Tail D F Head E a Tail E b, c Head b, c b, c Tail b, c Head b, c b Tail b, c c Head c c Tail c * 广义表的两个特殊的基本运算 取表头head LS 取表尾tail LS 广义表的基本运算 * 任何一个非空广义表的表头是表中第一个元素,可以是数据元素,也可以是子表,而其表尾一定是子表。 L a, b, c E A x, L, z B A, y, E C A, B D z,

文档评论(0)

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

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

版权声明书
用户编号:5311233133000002

1亿VIP精品文档

相关文档