ch5数组和广义表

ch5数组和广义表

ID:40838408

大小:363.00 KB

页数:37页

时间:2019-08-08

ch5数组和广义表_第1页
ch5数组和广义表_第2页
ch5数组和广义表_第3页
ch5数组和广义表_第4页
ch5数组和广义表_第5页
资源描述:

《ch5数组和广义表》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第五章数组和广义表一、教学内容:1、数组的定义和运算2、数组的顺序存储结构3、矩阵的压缩存储4、广义表的定义5、广义表的存储结构二、教学要求:了解稀疏矩阵的三元组和十字链表存储结构和基本运算;理解稀疏矩阵和特殊矩阵进行压缩存储的方法及下标变换;理解广义表的基本概念,掌握广义表的特点及存储结构;掌握数组的两种存储表示方法,特别是以行为主的存储结构中的地址计算方法;目录5.1数组的定义5.2数组的顺序表示和实现5.3矩阵的压缩存储5.4广义表的定义本章总结5.1数组的定义和特点定义:数组可以看成是一种特殊的线性表,即线性表中数据

2、元素本身也是一个线性表.数组特点数组结构固定(具有固定的上界和下界)数据元素同构(元素类型相同)数组运算给定一组下标,存取相应的数据元素给定一组下标,修改数据元素的值()()()()()()()()()在C语言中,一个二维数组类型可以定义为其分量类型为一维数组类型的一维数组类型typedefElemTypeArray2[m][n];等价于typedefElemTypeArray1[n];typedefArray1Array2[m];如:Array2A;//数组一旦被定义,它的维数和维界就不再改变。二维的数组=定长的线性表a1

3、1a12a13...a1na21a22a23...a2nAmxn=......am1am2am3...amnAm*n=((a11,a12,a13,...a1n),(a21,a22,a23,...a2n),...,(am1,am2,am3,...amn))数组的抽象数据类型ADTArray{数据对象:D={aj1j2...jn

4、n(>0)称为数组的维数,bi是数组第i维的长度,ji是数组元素的第i维下标,aj1j2...jn属于Elemset}数据关系:R={R1,R2...Rn}Ri={<aj1...ji...jn,aj1.

5、..ji+1...jn>

6、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)}ADTArray5.2数组的顺序表示和实现由于计算机的内存结构是一维的,因此用一维内存来表示多维数组,就必须按某种次序将数组元素

7、排成一列序列,然后将这个线性序列存放在存储器中。又由于对数组一般不做插入和删除操作,也就是说,数组一旦建立,结构中的元素个数和元素间的关系就不再发生变化。因此,一般都是采用顺序存储的方法来表示数组。通常有两种顺序存储方式:以行序为主序以列序为主序a11a12……..a1na21a22……..a2nam1am2……..amn………………….Loc(aij)=Loc(a11)+[(i-1)n+(j-1)]*l按行序为主序存放amn……..am2am1……….a2n……..a22a21a1n…….a12a1101n-1m*n-1n

8、按列序为主序存放01m-1m*n-1mamn……..a2na1n……….am2……..a22a12am1…….a21a11a11a12……..a1na21a22……..a2nam1am2……..amn………………….Loc(aij)=Loc(a11)+[(j-1)m+(i-1)]*l无论规定行优先或列优先,只要知道以下三要素便可随时求出任一元素的地址(这样数组中的任一元素便可以随机存取!):①开始结点的存放地址(即基地址)②维数和每维的上、下界;③每个数组元素所占用的单元数数组的应用生命细胞游戏魔术方阵5.3矩阵的压缩存储矩

9、阵:二维数组特殊矩阵:大量重复元素或大量0元素稀疏矩阵:大量0元素压缩存储:重复元素只分配一个存储空间,0元素不分配存储空间5.3.1特殊矩阵1.对称矩阵:aij=aji(1<=i,j<=n)a11a12….……..a1na21a22……..…….a2nan1an2……..ann………………….a11a21a22a31a32an1ann…...…...k=01234n(n-1)/2n(n+1)/2-1按行序为主序:每两个对称的元素共享一个存储空间,这样,能节约近一半的存储空间。对称矩阵顺序存储实例:15137a0050800

10、a10a1118926a20a21a2330251………………..70613an-10an-11an-12…an-1n-1在这个下三角矩阵中,元素总数为:n(n+1)/2因此,我们可以按从上到下、从左到右访问对称矩阵A中的元素,若i≧j,则aij在下三角形中。aij之前的i行一共有1+2+

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。