第5章-数组和广义表_第1页
第5章-数组和广义表_第2页
第5章-数组和广义表_第3页
第5章-数组和广义表_第4页
第5章-数组和广义表_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第2章线性表第3章栈和队列第4章串第5章数组和广义表

可表示为:(a1,a2,……,an)线性结构北京林业大学信息学院第5章数组和广义表5.1数组的定义5.2数组的顺序表示和实现5.3矩阵的压缩存储5.4广义表的定义5.5广义表的存储结构教学内容北京林业大学信息学院1.

掌握数组在以行为主的存储结构中的地址计算方法2.了解稀疏矩阵的压缩存储表示方法的特点3.掌握广义表的定义、性质、表示及其GetHead和GetTail的操作

教学目标北京林业大学信息学院①元素的值并非原子类型,可以再分解,表中元素也是一个线性表(即广义的线性表)。②所有数据元素仍属同一数据类型。数组和广义表的特点:一种特殊的线性表注意:本章所讨论的数组与高级语言中的数组区别:高级语言中的数组是顺序结构;而本章的数组既可以是顺序的,也可以是链式结构,用户可根据需要选择。北京林业大学信息学院5.1数组的定义数组的抽象数据类型数据对象:数据关系:ADTArray{北京林业大学信息学院基本操作:

(1)InitArray(&A,n,bound1,

boundn)//构造数组A(2)DestroyArray(&A)//销毁数组A(3)Value(A,&e,index1,…,indexn)//取数组元素值

(4)Assign(A,&e,index1,…,indexn)//给数组元素赋值}ADTArray北京林业大学信息学院一维数组352749186054778341020123456789llllllllll

LOC(i)=LOC(i-1)+l=a+i*lLOC(i)=

LOC(i-1)+l=a+i*l,i>0

a,i=0

a+i*la北京林业大学信息学院二维数组北京林业大学信息学院以行序为主序C,PASCAL5.2数组的顺序表示和实现北京林业大学信息学院以列序为主序FORTRAN北京林业大学信息学院

a[n][m]设数组开始存放位置LOC(0,0)=a

LOC(j,k)=a+j*m+k二维数组的行序优先表示北京林业大学信息学院①②③三维数组按页/行/列存放,页优先的顺序存储

北京林业大学信息学院a[m1][m2][m3]

各维元素个数为

m1,m2,m3

下标为

i1,i2,i3的数组元素的存储位置:

LOC(i1,i2,i3)=a+i1*m2*m3+i2*m3+i3前i1页总元素个数第i1页的前i2行总元素个数第i2行前i3列元素个数三维数组北京林业大学信息学院

各维元素个数为

m1,m2,m3,…,mn

下标为i1,i2,i3,…,in

的数组元素的存储位置:

n维数组北京林业大学信息学院n维数组北京林业大学信息学院设有一个二维数组A[m][n]按行优先顺序存储,假设A[0][0]存放位置在644(10),A[2][2]存放位置在676(10),每个元素占一个空间,问A[3][3](10)存放在什么位置?脚注(10)表示用10进制表示。设数组元素A[i][j]存放在起始地址为Loc(i,j)的存储单元中∵Loc(2,2)=Loc(0,0)+2*n+2=644+2*n+2=676.∴n=(676-2-644)/2=15∴Loc(3,3)=Loc(0,0)+3*15+3=644+45+3=692.练习北京林业大学信息学院设有二维数组A[10,20],其每个元素占两个字节,第一个元素的存储地址为100,若按行优先顺序存储,则元素A[6,6]的存储地址为

,按列优先顺序存储,元素A[6,6]的存储地址为

。练习352232(6*20+6)*2+100=352(6*10+6)*2+100=232北京林业大学信息学院5.3矩阵的压缩存储1.什么是压缩存储?若多个数据元素的值都相同,则只分配一个元素值的存储空间,且零元素不占存储空间。2.什么样的矩阵能够压缩?

一些特殊矩阵,如:对称矩阵,对角矩阵,三角矩阵,稀疏矩阵等。3.什么叫稀疏矩阵?矩阵中非零元素的个数较少(一般小于5%)北京林业大学信息学院三元组表:((1,2,12),(1,3,9),(3,1,-3),(3,6,14),(4,3,24),(5,2,18),(6,1,15),(6,4,-7))压缩存储原则:每个非零元的行下标、列下标和元素值稀疏矩阵北京林业大学信息学院

#defineMAXSIZE125000//设非零元素最大个数125000

typedef

struct{

inti;//元素行号

intj;//元素列号

ElemTypee;//元素值}Triple;typedef

struct{

Tripledata[MAXSIZE+1];//三元组表

int

mu;//矩阵总行数

int

nu;//矩阵总列数

int

tu;//矩阵中非零元素总个数}TsMatrix;//一个结点的结构定义三元组表的顺序存储表示北京林业大学信息学院typedef

struct{Tripledata[MAXSIZE+1];//非零三元组表

intrpos[MAXRC+1];//各行第一个非零元素的位置表

int

mu,nu,tu;//矩阵的行数,列数和非零元素个数}RLSMatrix;行逻辑链接的顺序存储表示北京林业大学信息学院rowcolvaldownright113418225234^^^^^^^链式存储结构(十字链表)同一列中下一非零元素的指针同一行中下一非零元素的指针北京林业大学信息学院十字链表的特点:①每行非零元素通过right域链接成一个线性链表②每列非零元素通过down域链接成一个线性链表则每个非零元素既是行链表中的一个结点;又是列链表中的一个结点,即呈十字链状。方法:每个非0元素占用5个域用途:方便稀疏矩阵的加减运算链式存储结构(十字链表)rowcolvaldownright北京林业大学信息学院5.4广义表的定义广义表(列表):n(0)个表元素组成的有限序列,记作LS=(a0,a1,a2,…,an-1)

LS是表名,ai

是表元素,它可以是表(称为子表),可以是数据元素(称为原子)。

n为表的长度。n=0的广义表为空表。北京林业大学信息学院线性表的成分都是结构上不可分的单元素广义表的成分可以是单元素,也可以是有结构的表线性表是一种特殊的广义表广义表不一定是线性表,也不一定是线性结构广义表与线性表的区别?北京林业大学信息学院广义表的抽象数据类型定义(教材P107-108)(1)求表头GetHead(L):非空广义表的第一个元素,表头可以是一个单元素,也可以是一个子表(2)求表尾GetTail(L):非空广义表除去表头元素以外其它元素所构成的表。表尾一定是一个表北京林业大学信息学院练习A=()

GetHead和GetTail均无定义A=(a,b)

GetHead(A)=aGetTail(A)=(b)

A=(a)

GetHead(A)=aGetTail(A)=()

A=((a))

GetHead(A)=(a)GetTail(A)=()

GetHead(GetTail(GetHead(GetTail(GetTail(A)))))

A=(a,b,(c,d),(e,(f,g)))

d北京林业大学信息学院1.GetTail【(b,k,p,h)】=

;2.GetHead【((a,b),(c,d))】=

;3.GetTail【((a,b),(c,d))】=

;4.GetTail【GetHead【((a,b),(c,d))】】=

;(k,p,h)(b)(a,b)5.GetTail【(e)】=

;6.GetHead【(())】=

.7.GetTail【(())】=

.()(a,b)()()((c,d))练习北京林业大学信息学院有次序性有长度有深度可递归可共享一个直接前驱和一个直接后继=表中元素个数=表中括号的重数自己可以作为自己的子表可以为其他广义表所共享广义表的特点北京林业大学信息学院E=(a,E)=(a,(a,E))=(a,(a,(a,…….))),E为递归表1)A=()2)B=(e)3)C=(a,(b,c,d))4)D=(A,B,C)5)E=(a,E)n=0,因为A是空表n=1,表中元素e是原子n=2,a为原子,(b,c,d)为子表n=3,3个元素都是子表n=2,a为原子,E为子表D=(A,B,C)=((),(e),(a,(b,c,d))),共享表练习:求下列广义表的长度北京林业大学信息学院ABDCeabcd

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论