- 1、本文档共37页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
ch5数组和广义表(冲突STEVEN–PC2006–08–2517–10–14)
第五章 数组和广义表 目 录 5.1 数组的定义和特点 定义:数组可以看成是一种特殊的线性表,即线性表中数据元素本身也是一个线性表. 数组的抽象数据类型 ADT Array { 数据对象:D = {aj1j2...jn | n(0)称为数组的维数,bi是数组第i维的长度, ji是数组元素的第i维下标, aj1j2...jn属于Elemset} 数据关系: R={R1 , R2 ... Rn} Ri = {< aj1...ji...jn, aj1...ji+1...jn >|0 ? jk? bk-1, 1 ? k ? n, aj1...ji...jn, aj1...ji+1...jn 属于D}。 基本操作: InitArray(A,n,bound1,bound2,...,boundn); DestroyArray (A); Value(A,e,index1,index2,...,indexn); Assign(A,e, index1,index2,...,indexn) }ADT Array 5.2 数组的顺序表示和实现 通常有两种顺序存储方式: 以行序为主序 以列序为主序 数组的应用 生命细胞游戏 魔术方阵 5.3 矩阵的压缩存储 矩阵: 二维数组 特殊矩阵: 大量重复元素或大量0元素 稀疏矩阵: 大量0元素 压缩存储: 重复元素只分配一个存储空间,0元素不分配存储空间 5.3.1 特殊矩阵 1.对称矩阵: aij = aji (1=i,j=n) 2.下三角矩阵: 当ij时, aij = 0, (0=i,j=n-1) 稀疏矩阵转置算法思想 显然,一个稀疏矩阵的转置仍然是一个稀疏矩阵,方法是:设将矩阵M转置为矩阵T (1)将矩阵的行列值交换 (2)将每一个三元组的i和j相互调换 (3)重排三元组之间的次序 可以有两种处理方法: 该算法主要工作是在p*col的两重循环中做的,所以时间复杂度是O(nu*tu)。而一般矩阵的转置算法是在nu*mu的两重循环中做的,时间复杂度是O(nu*mu)。当稀疏矩阵的非零元个数tu=nu*mu时,其时间复杂度O(nu*tu)=O(nu*nu*mu)=O(nu2*mu)大大高于一般矩阵的时间复杂度,所以该算法仅适用于tunu*mu的稀疏矩阵。 5.4 广义表 5.4.1 基本概念 5.4.2 广义表的存储结构 5.4.3 广义表的运算 5.4.1 基本概念 广义表(简称表):是n(n≥0)个元素的一个序列,若n=0时则称为空表。设ai为广义表的第i个元素,则广义表GL一般表示为: GL=(a1,a2,…,ai,ai+1,…,an) n表示广义表的长度,即广义表中所含元素的个数,n≥0。如果ai是单个数据元素,则称ai是广义表GL的原子;如果ai是一个广义表,则ai是广义表GL的子表。 当GL非空时,第一个元素a1称为该广义表的表头(head),除第一个元素外所有元素构成的表(a2,…,ai,ai+1,…,an)称为该广义表的表尾(tail)。显然,一个广义表的表头可以是原子或子表,但表尾始终是一个广义表。括号嵌套的最大次数称为广义表的深度。 A=( ); //A是一个空表 B=(e); //表B有一个原子 C=(a,(b,c,d)); //两个元素为原子a和子表 (b,c,d) D=(A,B,C); //有三个元素均为列表 E=(a,E); //递归的列表,包含两个元素,一个是单元素a,另一个是子表,但该子表是其自身.所以,E相当于一个无限的广义表( a,(a,(a,…))). 5.4.2 广义表的存储结构 通常采用链式存储结构。在广义表中原子和子表所含的信息不同,所以在存储时也有原子和子表之分。 广义表的头尾链接存储定义: 5.4.3 广义表的运算 求广义表的长度 求广义表的深度 建立广义表 输出广义表 求广义表的长度 分析:由于广义表中同一层的结点都是通过next指针域链接起来的,所以,可采用求单链表长度的方法。 实现算法:(略,可编写递归和非递归两种算法) 注意:广义表采用带有附加结点的链式存储结构。 两种算法的时间复杂度都是O(n)。由于在递归算法中需要为值参GL分配空间,用来存储指针值,所以其空间复杂度为O(n)。非递归算法的空间复杂度为O(1)。 求广义表的深度 分析:广义表深度的递归定义是它等于所有子表中表的最大深度加1,若一个表为空或仅由单元素所组成,则深度为1。递归函数如下:
您可能关注的文档
- CC语言第二章算法.ppt
- CDMA和DCN组网图.ppt
- bz第1节人口的数量变化1.ppt
- CCTV–4《远方的家》贴片广告介绍.ppt
- CDMA20001x信令流程和关键性能指标说明06.ppt
- CF穿越火线战场模式冰封要塞新手的教程.pptx
- cd–rd刻录技术介绍.ppt
- ch01项目管理导论xin–1.ppt
- ch01D文稿.ppt
- Ch14–提高软件设计质量.ppt
- 2025年高二学业水平测试动员大会发言稿范文 .pdf
- 2025年中国古典家具行业发展前景预测及投资规划建议报告.docx
- 中国户外照明行业发展监测及投资规划建议报告.docx
- 电力测量仪表项目安全评估报告.docx
- 治疗精神障碍药项目安全风险评价报告.docx
- 2024-2030年中国普惠金融行业挑战和机遇分析及投资战略建议报告版.docx
- 十章企业制度da01-16注会济法基础16zkjjf hjxjc.pdf
- 产业互联网项目风险评估报告.docx
- 2023-2029年中国环保瓷砖行业发展前景预测及投资规划建议报告.docx
- 2025年高压电工作业操作证考试题库及答案100题,含答案 .pdf
最近下载
- 江西农业大学2021-2022学年第1学期《高等数学(上)》期末考试试卷(B卷)及标准答案.pdf
- 施工组织设计-江城水泥混凝土土.doc VIP
- 山西农业大学2021-2022学年第1学期《高等数学(上)》期末考试试卷(A卷)及标准答案.pdf
- 八年级上语文 《红星照耀中国》纪实作品人教PPT课件优质课比赛公开课获奖.ppt
- B2C电子商务信任实证研究的现状与思考.doc
- 有理数乘方练习题.doc VIP
- 经典电动力学-北京大学物理学院.PDF
- 幂的乘方与积的乘方-练习题(含答案) .doc VIP
- 政府采购非招标方式概述 .ppt VIP
- 云南南博会会展服务中心招聘笔试真题2023.docx VIP
文档评论(0)