- 1、本文档共24页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构第五章:数组
* 第五章 数组和广义表 5.1 数组的定义 5.2 数组的顺序表示和实现 5.3 矩阵的压缩存储 5.4 广义表的定义 5.5 广义表的存储结构 5.1 数组的定义 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| Ri={aj1...ji...jn,aj1...ji+1 ...jn| 0=jk=bk-1,1=k=n且ki, 0=ji=bi-2,aj1...ji...jn, aj1...ji+1 ...jn(-D,i=2,...n} 基本操作: InitArray(A,n,bound1,...,boundn) DestroyArray(A) Value(A,e,index1,...,indexn) Assign(A,e,index1,...,indexn) }ADT Array 数据元素个数: (b1*b2*b3*…*bn) 每个数据元素aj1j2...jn受到n个关系的约束:R1,R2,…,Rn 数据元素aj1j2...jn在R1关系中的直接后继元素: a(j1+1)j2…jn aj1j2...jn (-ElemSet n(0)称为数组的维数, bi是数组第i维的长度, ji是数组元素的第i维下标. R={R1,R2,...Rn} Ri={aj1...ji...jn,aj1...ji+1 ...jn| 数据元素aj1j2...jn在R2关系中的直接后继元素: aj1(j2+1)…jn ……. 数据元素aj1j2...jn在Rn关系中的直接后继元素: aj1j2…(jn+1) 例子: 数组int a[3][7][5] 数据元素个数: 每个数据元素aj1j2j3受到3个关系的约束: 数据元素a[2][3][0]在R1关系中的直接后继元素: 105 R1,R2,R3 数据元素a[2][3][0]在R2关系中的直接后继元素: a[2][4][0] 数据元素a[2][3][0]在R3关系中的直接后继元素: a[2][3][1] 无 a00 a01 a02… a0,n-1 a10 a11 a12… a1,n-1 … … … am-1,0 am-1,1 am-1,2 … am-1,n-1 二维数组可看作是线性表的推广: 二维数组—— 是一个定长线性表,且它的每个数据元素也是一个定长线性表。 例: Am×n= a00 a01 a02… a0,n-1 a10 a11 a12… a1,n-1 … … … am-1,0 am-1,1 am-1,2 … am-1,n-1 (1) A=(α0,α1,…,αm-1) αi=(ai0,ai1,…,ai,n-1) 0=i=m-1 Am×n= α0 α1 … αm-1 = (2) A=(α0,α1,…,αn-1) αj=(a0j,a1j,…,am-1,j) 0=j=n-1 Am×n= α0 α1 …αn-1 = a00 a01 a02… a0,n-1 a10 a11 a12… a1,n-1 … … … am-1,0 am-1,1 am-1,2 … am-1,n-1 二维数组C语言的表示:
文档评论(0)