ch5数组和广义表.ppt

  1. 1、本文档共44页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第五章 数组和广义表 数组和广义表可看成是一种特殊的线性表,其特殊在于:表中的数据元素本身也是一种线性表。 数组的定义、存储 特殊矩阵的定义、存储和运算 广义表的定义、存储和运算 一、数组的定义和存储 数组的定义:数组是由一组类型相同的数据元素构成,每个数据元素称为一个数组元素(简称元素)。 每个元素受n 个线性关系约束(n≥1)。 每个关系中,元素都有一个直接后继元素。 二、特殊矩阵的定义、存储和运算 特殊矩阵:所谓特殊矩阵是指非零元素或零元素的分布有一定规律的矩阵。 对称矩阵 上 /下三角形矩阵 稀疏矩阵 压缩存储:为多个值相同的元素只分配一个存储空间;对零元素不分配存储空间。 三、广义表的定义、存储和运算 广义表(list)的定义:又称为列表,是n(n =0)个元素a1,a2,a3,…,an的有限序列,其中ai或者是原子项,或者是一个广义表。广义表通常记作: LS=(a1,a2,a3,…,an)。 其中:LS是广义表的名字,n为它的长度。 若ai是广义表,则称它为LS的子表。 第五章 小结 数组:逻辑定义、顺序存储结构 特殊矩阵的压缩存储:对称矩阵、上/下三角矩阵、稀疏矩阵(顺序存储、十字链) 广义表:逻辑定义、链式存储结构 作业 现有如下稀疏矩阵A,要求画出三元组表示法和十字链表示法。 有数组A[4][4],把1到16个整数分别按顺序放入A[0][0],…,A[0][3],A[1][0],…,A[1][3],A[2][0],…,A[2][3],A[3][0],…,A[3][3]中,编写一个算法获取数据,并求出两条对角线元素的乘积。 1 1 3 4 1 8 2 2 5 2 3 4 ^ ^ ^ ^ ^ ^ ^ 十字链表 十字链表的建立: 初始化:行指针数组rhead、列指针数组chead; 申请结点:p- i=i;p- j=j;p- e=e; 确定在行链表中的插入位置; 确定在列链表中的插入位置。 广义表的抽象数据类型定义: ADT GList { 数据对象:单个元素(原子)或子表 数据关系:线性关系 基本操作: }ADT GList; 广义表是一个多层次的线性结构。 例如:有A、B、C、D、E五个广义表的描述如下: A=( ) A是一个空表,它的长度为零。 B=(e) 列表B只有一个原子e,B的长度为1。 C=(a,(b,c,d)) 列表C的长度为2,两个元素分别为原子a和子表(b,c,d)。 D=(A,B,C) 列表D的长度为3,三个元素都是列表。 显然,将子表的值代入后,则有D=((),(e),(a,(b,c,d)))。 E=(a,E) 这是一个递归表,它的长度为2。 E相当于一个无限的列表E=(a,(a,(a,...)))。 广义表的结构特点: 广义表中的数据元素有相对次序; 广义表的长度定义为最外层包含的元素个数; 广义表的深度定义为所含括弧的重数; 注意: “原子”的深度为“0”,“空表”的深度为1。 表头可以是原子或列表;表尾必定是列表。 广义表可以是一个递归的表,递归表的深度是无穷值,长度是有限值。 !注:任何一个非空广义表 LS = ( ?1,?2,…… ,?n) 均可分解为两部分: 表头 Head(LS) = ?1 表尾 Tail(LS) = ( ?2, …… , ?n) 例如: Head( (( b, c)) ) = ( b,c) Tail( (( b, c)) ) = ( ) Head(( a,( b, c)) ) = a Tail( (a,( b, c)) ) = (( b,c )) Head( ( c ) ) = c Tail( ( c ) ) = ( ) 广义表的存储表示:广义表通常采用链式存储结构,每个元素可用一个结点表示。 第一种链式存储表示: 定义两种结点:原子结点—— 表示原子 表结点 —— 表示子表 tag=0 atom tag=1 hp tp 例如: A=() B=(e) C=(a,(b,c,d)) D=(A,B,C) E=(a,E) A=NULL B 1 ∧ 0 e C 1 1 ∧ 1 1 1 ∧ 0 a 0 b 0 c 0 d 1 1 ∧ 1 ∧ D 1 1 ∧ E 0 a !注意: 非空表的表头指针均指向一个表结点,hp指向

文档评论(0)

管理学科 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档