数据结构 第5章 数组
数据结构第五章 数组与广义表
压缩存储方法:只需要存储下三角 (含对角线)上的元素。可节省一 半空间。
可以使用一维数组Sa[n(n+1)/2]作为n阶对称矩阵A的存 储结构,且约定以行序为主序存储各个元素,则在Sa[k]和矩
阵元素aij之间存在一一对应关系: (下标变换公式)
i(i+1)/2 + j 当i≥j k = j(j+1)/2 + i 当i<j
q = cpot[col];
T.data[q].i = M.data[p].j; T.data[q].j = M.data[p].i; T.data[q].e = M.data[p].e; ++cpot[col]; }
分析算法FastTransposeSMatrix的时间 复杂度:
for (col=1; col<=M.nu; ++col) … … for (t=1; t<=M.tu; ++t) … … for (col=2; col<=M.nu; ++col) … … for (p=1; p<=M.tu; ++p) … …
//对当前行中每一个非零元
处
brow=M.data[p].j;
理
if (brow < N.nu ) t = N.rpos[brow+1];
M
else { t = N.tu+1 }
的
for (q=N.rpos[brow]; q< t; ++q) { ccol = N.data[q].j; // 乘积元素在Q中列号
一、三元组顺序表
对于稀疏矩阵,非零元可以用三元组表示, 整个稀疏矩阵可以表示为所有非零元的三元组所 构成的线性表。例如:
《刘大有数据结构》 chapter 5 数组字符串和集合类
再例如三维数组 再例如三维数组D[3][3][4],可以把它看作一维 , 数组 B1[3] = { D[0][3][4],D[1][3][4],D[2][3][4] } , ,
下面我们给出一个 下面我们给出一个Array类的应用例子 类的应用例子. 类的应用例子 例5.1 编写一个函数,要求输入一个整数 , 编写一个函数,要求输入一个整数N, 用动态数组A来存放 来存放2~ 之间所有 之间所有5或 的倍数 的倍数, 用动态数组 来存放 ~N之间所有 或7的倍数, 输出该数组. 输出该数组 说明 : 因为 由用户给出 , 编写程序时无法知 说明:因为N由用户给出 由用户给出, 道需要多大的数组来存放数据, 道需要多大的数组来存放数据,因此采用动态 数组(初始时大小为10) 数组(初始时大小为 ),每当数组满时就调 整数组大小,给它增加10个元素 个元素. 整数组大小,给它增加 个元素
数组在内存中一般是以顺序方式存储的 数组在内存中一般是以顺序方式存储的. 设一维数组 设一维数组A[n]存放在 个连续的存储单元中 , 存放在n个连续的存储单元中 存放在 个连续的存储单元中, 每个数组元素占一个存储单元(不妨设为C个 每个数组元素占一个存储单元 ( 不妨设为 个 连续字节) 如果数组元素A[0]的首地址是 , 的首地址是L, 连续字节). 如果数组元素 的首地址是 则 A[1] 的 首 地 址 是 L+C , A[2] 的 首 地 址 是 L+2C,… …,依次类推,对于 0 ≤ i ≤ n 1 有: , ,依次类推,
B[i]={ A[i][0],A[i][1],…,A[i][n-2],A[i][n-1] } -
《数据结构与算法》第五章-数组和广义表学习指导材料
《数据结构与算法》第五章数组和广义表本章介绍的数组与广义表可视为线性表的推广,其特点是数据元素仍然是一个表。
本章讨论多维数组的逻辑结构和存储结构、特殊矩阵、矩阵的压缩存储、广义表的逻辑结构和存储结构等。
5.1 多维数组5.1.1 数组的逻辑结构数组是我们很熟悉的一种数据结构,它可以看作线性表的推广。
数组作为一种数据结构其特点是结构中的元素本身可以是具有某种结构的数据,但属于同一数据类型,比如:一维数组可以看作一个线性表,二维数组可以看作“数据元素是一维数组”的一维数组,三维数组可以看作“数据元素是二维数组”的一维数组,依此类推。
图5.1是一个m行n列的二维数组。
5.1.2 数组的内存映象现在来讨论数组在计算机中的存储表示。
通常,数组在内存被映象为向量,即用向量作为数组的一种存储结构,这是因为内存的地址空间是一维的,数组的行列固定后,通过一个映象函数,则可根据数组元素的下标得到它的存储地址。
对于一维数组按下标顺序分配即可。
对多维数组分配时,要把它的元素映象存储在一维存储器中,一般有两种存储方式:一是以行为主序(或先行后列)的顺序存放,如BASIC、PASCAL、COBOL、C等程序设计语言中用的是以行为主的顺序分配,即一行分配完了接着分配下一行。
另一种是以列为主序(先列后行)的顺序存放,如FORTRAN语言中,用的是以列为主序的分配顺序,即一列一列地分配。
以行为主序的分配规律是:最右边的下标先变化,即最右下标从小到大,循环一遍后,右边第二个下标再变,…,从右向左,最后是左下标。
以列为主序分配的规律恰好相反:最左边的下标先变化,即最左下标从小到大,循环一遍后,左边第二个下标再变,…,从左向右,最后是右下标。
例如一个2×3二维数组,逻辑结构可以用图5.2表示。
以行为主序的内存映象如图5.3(a)所示。
分配顺序为:a11 ,a12 ,a13 ,a21 ,a22,a23 ; 以列为主序的分配顺序为:a11 ,a21 ,a12 ,a22,a13 ,a23 ; 它的内存映象如图5.3(b)所示。
《数据结构——用C语言描述(第二版)》第5章 数组和广义表
第五章 数组和广义表
在压缩存储时,矩阵中值相同的元素C可共享一个存储空间,元素 为零则可不必分配空间,而其余的元素有 n(n+1)/2个,因此三角矩阵 可用一维数组M[n×(n+1)/2+1]来存储,其中常数C放在数组的最后一 个下标变量中。
假设A和B矩阵分别用matrix型指针变量a和b表示,矩阵的转置可以 按以下进行:由于B的行是A的列,所以可按照b->data三元组表的次序在 a->data中找到相应的三元组进行转置,即可按a->data的列序转置,所得 到的转置矩阵B的三元组表b->data必定是按行优先存放的。因此,可以对 三元组表a->data从第一行起扫描,找到A的每一列中所有的非零元素,就 可以实现转置。
LOC ( aij ) =LOC ( a00) +(i×n+j) × c 同理可推导出以列为主序优先存储时数据元素a i j 的存储地址,其计算公式 为:
LOC( a i j ) =LOC( a00 ) +( j × n +i ) × c 对于三维数组Am×n×p而言,若以行为主序优先存储时,则其数据元 素aijk的存储地址可为: LOC ( a i j k) =LOC ( a000) +[ i × m×p +j ×p +k] × c 对于一般的二维数组A[c1…d1,c2…d2]而言,此处c1,c2的值不一定是 0,a i j 的地址为: LOC ( a i j ) =LOC ( a c 1 c 2 ) +[ ( i – c 1 )* ( d 2 – c 2 +1) +j – c 2 ] * c
第5章演示
对称矩阵的压缩存储
(2)压缩存储: ③数组Sa中的元素与矩阵元素aij存在着一一对应的 关系。 假设数组元素Sa[k]中存放的是矩阵元素aij,则它们 之间的对应关系实质上就是下标值k和i、j之间的对应 关系。
对称矩阵的压缩存储的下标转换公式为:
i(i-1)/2+(j-1),当i>=j k= j(j-1)/2+(i-1),当i<j
稀疏矩阵
3、稀疏矩阵的存储结构 (2)算法:将矩阵M转置为矩阵T
M.data M.data[1] 1 2 12 M.data[2] 1 3 9 M.data[3] 3 M.data[4] 3 M.data[5] 4 M.data[6] 5 M.data[7] 6 M.data[8] 6 1 6 3 -3 14 24 T.data T.data[1] 1 3 -3 T.data[2] 1 6 15
稀疏矩阵的三元组表表示法节约了存储空间, 实现了压缩存储。
稀疏矩阵
注意:
稀疏矩阵 唯一 三元组表
不唯一
解决办法:在三元表的基础上,再引入总行数、 总列数和非零元素总个数即可。
稀疏矩阵
3、稀疏矩阵的存储结构 (1)三元组顺序表 以顺序存储结构表示的三元组表。 三元组类型定义: typedef struct { int i,j; elemtype e; }Triple;
5.4 广义表的定义
二、表示 (1)用关系定义表示; (2)用图表示。 说明: ①广义表是一个多层次结构; ②广义表之间可以共享; ③广义表可以递归定义; ④表头可以为原子或子表;表尾只能为子表; ⑤( )与( ( ) )不同。
5.4 广义表的定义 A =( ) B =(e) C =(a, (b,c,d)) D =(A, B, C) E =(a, E) F =(( ))
数据结构第5章
第5章:数组和广义表 1. 了解数组的定义;填空题:1、假设有二维数组A 6×8,每个元素用相邻的6个字节存储,存储器按字节编址。
已知A 的起始存储位置(基地址)为1000,则数组A 的体积(存储量)为 288 B ;末尾元素A 57的第一个字节地址为 1282 。
2、三元素组表中的每个结点对应于稀疏矩阵的一个非零元素,它包含有三个数据项,分别表示该元素的 行下标 、 列下标 和 元素值 。
2. 理解数组的顺序表示方法会计算数组元素顺序存储的地址;填空题:1、已知A 的起始存储位置(基地址)为1000,若按行存储时,元素A 14的第一个字节地址为 (8+4)×6+1000=1072 ;若按列存储时,元素A 47的第一个字节地址为 (6×7+4)×6+1000)=1276 。
(注:数组是从0行0列还是从1行1列计算起呢?由末单元为A 57可知,是从0行0列开始!) 2、设数组a[1…60, 1…70]的基地址为2048,每个元素占2个存储单元,若以列序为主序顺序存储,则元素a[32,58]的存储地址为 8950 。
答:不考虑0行0列,利用列优先公式: LOC(a ij )=LOC(a c 1,c 2)+[(j-c 2)*(d 1-c 1+1)+i-c 1)]*L 得:LOC(a 32,58)=2048+[(58-1)*(60-1+1)+32-1]]*2=8950选择题:( A )1、假设有60行70列的二维数组a[1…60, 1…70]以列序为主序顺序存储,其基地址为10000,每个元素占2个存储单元,那么第32行第58列的元素a[32,58]的存储地址为 。
(无第0行第0列元素)A .16902B .16904C .14454D .答案A, B, C 均不对 答:此题(57列×60行+31行)×2字节+10000=16902( B )2、设矩阵A 是一个对称矩阵,为了节省存储,将其下三角部分(如下图所示)按行序存放在一维数组B[ 1, n(n-1)/2 ]中,对下三角部分中任一元素a i,j (i ≤j), 在一维数组B 中下标k 的值是:A .i(i-1)/2+j-1B .i(i-1)/2+jC .i(i+1)/2+j-1D .i(i+1)/2+j3、从供选择的答案中,选出应填入下面叙述 ? 内的最确切的解答,把相应编号写在答卷的对应栏内。
《数据结构》第五章 数组 习题
《数据结构》第五章 数组 习题基本概念题:5-1 分别写出一维数组和二维数组的存储映象公式。
5-2 什么叫二维数组的行序优先存储?什么叫二维数组的列序优先存储?C 语言采用的是行序优先存储还是列序优先存储?5-3 什么叫随机存储结构?为什么说数组是一种随机存储结构?5-4 动态数组和静态数组在使用方法上有什么不同?5-5 什么样的矩阵叫特殊矩阵?特殊矩阵压缩存储的基本思想是什么?5-6 什么样的矩阵叫稀疏矩阵?稀疏矩阵压缩存储的基本思想是什么?5-7 什么叫稀疏矩阵的三元组?什么叫稀疏矩阵的三元组线性表?5-8 稀疏矩阵主要有哪些压缩存储结构?复杂概念题:5-9 设一个系统中二维数组采用以行序为主的存储方式存储,已知二维数组a[n][m]中每个数据元素占k 个存储单元,且第一个数据元素的存储地址是Loc(a[0][0]),求数据元素a[i][j](0≤i≤n -1, 0≤j≤m -1)的存储地址。
5-10 设一个系统中二维数组采用以行序为主的存储方式存储,已知二维数组a[10][8]中每个数据元素占4个存储单元,且第一个数据元素的存储地址是1000,求数据元素a[4][5]的存储地址。
5-11 画出一个3行3列二维动态数组存储结构示意图。
5-12 对于如下所示的稀疏矩阵A(1)写出该稀疏矩阵的三元组线性表;(2)画出稀疏矩阵A 的三元组顺序表结构;(3)画出稀疏矩阵A 的带头结点单链表结构;(4)画出稀疏矩阵A 的行指针数组链表结构;(5)画出稀疏矩阵A 的三元组十字链表结构。
算法设计题:5-13 为节省内存,n 阶对称矩阵采用压缩存储,要求:(1)编写实现C = A + B 操作的函数。
设矩阵A 、矩阵B 和矩阵C 均采用压缩存储方式存储,矩阵元素均为整数类型。
(2)编写一个采用压缩存储的n 阶对称矩阵的输出函数,要求输出显示成矩阵形式,设矩阵元素均为整数类型。
(3)设矩阵A 和矩阵B 为如下所示的矩阵,编写一个用矩阵A 和矩阵B 作为测试例子的测试上述函数的主程序。
数据结构课件PPT数组和广义表
{ q=1; for (col=1;col<=T.mu;++col) for(p=1;p<=M.tu;++p) if ( M.data[p].j==col ) { T.data[q].i=M.data[p].j; T.data[q].j=M.data[p].i; T.data[q].e=M.data[p].e; ++q; } }
(row) (col) (value)
[0] 1 4 22
[0] 1 5 91
[1] 1 7 15
[1] 2 2 11
[2] 2 2 11
[2] 3 6 28
[3] 2 [4] 3来自6 17 4 -6[3] 4 [4] 4
1 22 3 -6
[5] 4 6 39
[5] 6 2 17
[6] 5 1 91
[6] 6 4 39
cpot[1]=1 cpot[col]=cpot[col-1]+num[col-1]
稀疏矩阵的快速转置(算法5.2)
Status FastTransposeSMatrix(TSMatrix M,TSMatrix &T) { T.mu=M.nu; T.nu=M.mu; T.tu=M.tu;
if (T.tu) { for (col=1;col<=M.nu;++col) num[col]=0; for (t=1;t<=M.tu;++t) ++num[M.data[t].j]; cpot[1]=1; for ( col=2;col<=M.nu;++col) cpot[col]=cpot[col-1]+num[col-1]; for (p=1;p<=M.Tu;++p) { col=M.data[p].j; q=cpot[col]; T.data[q].i=M.data[p].j; T.data[q].j=M.data[p].i; T.data[q].e=M.data[p].e; ++cpot[col]; } }
数据结构 第5章 数组练习题
数据结构第5章数组练习题数据结构-第5章--数组练习题第五章阵列一、选择题3.有一个数组a[I,J],数组中每个元素的长度是3字节,I的值是1到8,J的值是1到10。
数组从内存ba的第一个地址开始顺序存储。
当它主要按列存储时,元素a[5,8]的第一个地址是(a)。
a.ba+141b.ba+180c.ba+222d.ba+2254.假设以行序为主序存储二维数组a=array[1..100,1..100],设每个数据元素占2个存储单元,基地址为10,则loc[5,5]=(a)。
a.808b.818c.1010d.10205.数组a[0..5,0..6]的每个元素占五个字节,将其按列优先次序存储在起始地址为1000的内存单元中,则元素a[5,5]的地址是()。
1195a、 1175b。
1180摄氏度。
1205d。
一千二百一十7.将一个a[1..100,1..100]的三对角矩阵,按行优先存入一维数组b[1e298]中,a中元素a6665(即该元素下标i=66,j=65),在b数组中的位置k为()。
供选择的答案:a、 198b年。
195c年。
1972+64*3=19410. 如果行序是n阶对称矩阵A的主序,则其下三角形的元素(包括主对角线上的所有元素)存储在一维数组B[1(n(n+1))/2]中,然后在bj*(j-1)/2+ic中确定AIJ(IA.I*(I-1)/2+JB。
i*(i+1)/2+jd。
j*(j+1)/2+i11。
设a是n*n的对称矩阵,将a的对角线和对角线上方的元素按列的顺序存储在一维数组B[1..n(n+1)/2]中,并存储上述任何元素的位置AIJ(1)≤ 一、J≤ n、而我≤ J)在B中是(c)。
a、 i(i-l)/2+jb。
j(j-l)/2+ic。
j(j-l)/2+i-1d。
i(i-l)/2+j-112。
A[n,n]是一个对称矩阵。
如果下三角形(包括对角线)按行顺序存储在尺寸组t[n(n+1)/2]中,则与任何上三角形元素a[i][J]对应的t[k]的下标k为(AB)。
数据结构第五章数组和广义表
数据结构第五章数组和广义表(总6页)--本页仅作为文档封面,使用时请直接删除即可----内页可以根据需求调整合适字体及大小--第五章数组和广义表:习题习题一、选择题1.假设以行序为主序存储二维数组A[1..100,1..100],设每个数据元素占两个存储单元,基地址为10,则LOC(A[5,5])=( )。
A. 808B. 818C. 1010D. 10202.同一数组中的元素( )。
A. 长度可以不同 B.不限 C.类型相同 D. 长度不限3.二维数组A的元素都是6个字符组成的串,行下标i的范围从0到8,列下标j的范圈从1到10。
从供选择的答案中选出应填入下列关于数组存储叙述中( )内的正确答案。
(1)存放A至少需要( )个字节。
(2)A的第8列和第5行共占( )个字节。
(3)若A按行存放,元素A[8]【5]的起始地址与A按列存放时的元素( )的起始地址一致。
供选择的答案:(1)A. 90 B. 180 C. 240 D. 270(2) A. 108 B. 114 C. 54 D. 60(3)[8][5] B. A[3][10] [5][8] [O][9]4.数组与一般线性表的区别主要是( )。
A.存储方面B.元素类型方面C.逻辑结构方面D.不能进行插入和删除运算5.设二维数组A[1..m,1..n]按行存储在数组B[1..m×n]中,则二维数组元素A[i,j]在一维数组B中的下标为( )。
A. (i-l)×n+jB. (i-l)×n+j-lC.i×(j-l) D. j×m+i-l6.所谓稀疏矩阵指的是( )。
A.零元素个数较多的矩阵B.零元素个数占矩阵元素中总个数一半的矩阵C.零元素个数远远多于非零元素个数且分布没有规律的矩阵D.包含有零元素的矩阵7.对稀疏矩阵进行压缩存储的目的是( )。
A.便于进行矩阵运算B.便于输入和输出C.节省存储空间D. 降低运算的时间复杂度8.稀疏矩阵一般的压缩存储方法有两种,即( )。
数据结构第五章数组和广义表
第五章数组和广义表:习题习题一、选择题1.假设以行序为主序存储二维数组A[1..100,1..100],设每个数据元素占两个存储单元,基地址为10,则LOC(A[5,5])=( )。
A. 808B. 818C. 1010D. 10202.同一数组中的元素( )。
A. 长度可以不同 B.不限 C.类型相同 D. 长度不限3.二维数组A的元素都是6个字符组成的串,行下标i的范围从0到8,列下标j的范圈从1到10。
从供选择的答案中选出应填入下列关于数组存储叙述中( )内的正确答案。
(1)存放A至少需要( )个字节。
(2)A的第8列和第5行共占( )个字节。
(3)若A按行存放,元素A[8]【5]的起始地址与A按列存放时的元素( )的起始地址一致。
供选择的答案:(1)A. 90 B. 180 C. 240 D. 270(2) A. 108 B. 114 C. 54 D. 60(3)[8][5] B. A[3][10] [5][8] [O][9]4.数组与一般线性表的区别主要是( )。
A.存储方面B.元素类型方面C.逻辑结构方面D.不能进行插入和删除运算5.设二维数组A[1..m,1..n]按行存储在数组B[1..m×n]中,则二维数组元素A[i,j]在一维数组B中的下标为( )。
A. (i-l)×n+jB. (i-l)×n+j-lC.i×(j-l) D. j×m+i-l6.所谓稀疏矩阵指的是( )。
A.零元素个数较多的矩阵B.零元素个数占矩阵元素中总个数一半的矩阵C.零元素个数远远多于非零元素个数且分布没有规律的矩阵D.包含有零元素的矩阵7.对稀疏矩阵进行压缩存储的目的是( )。
A.便于进行矩阵运算B.便于输入和输出C.节省存储空间D. 降低运算的时间复杂度8.稀疏矩阵一般的压缩存储方法有两种,即( )。
A.二维数组和三维数组B.三元组和散列C.三元组和十字链表D.散列和十字链表9.有一个100×90的稀疏矩阵,非0元素有10个,设每个整型数占两字节,则用三元组表示该矩阵时,所需的字节数是( )。
数据结构(C语言版)第5章数组
数据结构
数组和广义表可看成是一种特殊的线性表,其特 殊在于,表中的数据元素本身也是一种线性表。
5.1 数组的定义
由于数组中各元素具有统一的类型,并且数组元素的下标一 般具有固定的上界和下界,因此,数组的处理比其它复杂 的结构更为简单。多维数组是向量的推广。例如,二维数 组:
(a11 (a 21 ( ... ( m1 a
m1 m2
mn
Loc(aij)=Loc(aa )+[(j-1)m+(i-1)]*l Loc( aij)=Loc( 11 )+[(i-1)n+(j-1)]*l 11
m*n-1 m*n-1
数据结构
无论规定行优先或列优先,只要知道以下三要素便可随时求出 任一元素的地址(这样数组中的任一元素便可以随机存取!): ①开始结点的存放地址(即基地址) ②维数和每维的上、下界; ac1,c2 … ac1,d2 ③每个数组元素所占用的单元数 Amn= … aij … ad1,c2 … ad1,d2 计算二维数组元素地址的通式
数据结构
第五章
一、教学内容:
1、 2、 3、 4、 数组的定义和顺序存储方式; 特殊矩阵的压缩存储; 稀疏矩阵
数组和广义表
广义表的概念、表示及基本操作;广义表存储结构的实现。
二、教学要求:
1、 法; 2、 3、 掌握对特殊矩阵进行压缩存储时的下标变换公式; 了解稀疏矩阵的两种压缩存储方法的特点和适用范围,理解以三元组表示稀疏矩阵 了解数组的两种存储表示方法,并掌握数组在以行为主的存储结构中的地址计算方
a00 a01 a10 a11 a12 a21 … … a n-1 n-2 a n-1 n-1
K=0 1 2 3 4 5 … … 3n-2 3n-1 数组sa中的元素sa[k]与三对角带状矩阵中的元 素aij存在一一对应关系,在aij之前有i行,共有3*i-1 个非零元素,在第i行,有j-i+1个非零元素,这样, 非零元素aij的地址为:
数据结构课后习题答案第五章数组与广义表
第五章数组与广义表一、假设有二维数组A6*8,每个元素用相邻的6个字节存储,存储器按字节编址。
已知A的起始存储位置(基地址)为1000。
计算:1、数组A的体积(即存储量);2、数组A的最后一个元素a57的第一个字节的地址;3、按行存储时,元素a14的第一个字节的地址;4、按列存储时,元素a47的第一个字节的地址;答案:1、(6*8)*6=2882、loc(a57)=1000+(5*8+7)*6=1282或=1000+(288-6)=12823、loc(a14)=1000+(1*8+4)*6=10724、loc(a47)=1000+(7*6+4)*6=1276二、假设按低下标(行优先)优先存储整数数组A9*3*5*8时第一个元素的字节地址是100,每个整数占四个字节。
问下列元素的存储地址是什么?(1)a0000(2)a1111(3)a3125 (4)a8247答案:(1)100(2)loc(a1111)=100+(1*3*5*8+1*5*8+1*8+1)*4=776(3) loc(a3125)=100+(3*3*5*8+1*5*8+2*8+5)*4=1784(4) loc(a8247)=100+(8*3*5*8+2*5*8+4*8+7)*4=4416五、设有一个上三角矩阵(aij)n*n,将其上三角元素逐行存于数组B[m]中,(m 充分大),使得B[k]=aij且k=f1(i)+f2(j)+c。
试推导出函数f1,f2和常数C(要求f1和f2中不含常数项)。
答:K=n+(n-1)+(n-2)+…..+(n-(i-1)+1)+j-i=(i-1)(n+(n-i+2))/2+j-i所以f1(i)=(n+1/2)i-1/2i2f2(j)=jc=-(n+1)九、已知A为稀疏矩阵,试从空间和时间角度比较采用两种不同的存储结构(二维数组和三元组表)完成∑aii运算的优缺点。
(对角线求和)解:1、二维数组For(i=1;i<=n;i++)S=s+a[i][i];时间复杂度:O(n)2、for(i=1;i<=m.tu;i++)If(a.data[k].i==a.data[k].j) s=s+a.data[k].value;时间复杂度:O(n2)二十一、当稀疏矩阵A和B均以三元组表作为存储结构时,试写出矩阵相加的算法,其结果存放在三元组表C中。
数据结构第五章 数组和广义表
5.3.1
特殊矩阵
1、对称矩阵 在一个n阶方阵A中,若元素满足下述性质: aij = aji 1≤i,j≤n 则称A为对称矩阵。 a11 1 5 1 3 7 a21 a 22 5 0 8 0 0 a31 a32 a33 1 8 9 2 6 ……………….. 3 0 2 5 1 an 1 a n 2 a n 3 …a n n 7 0 6 1 3
第5章
数组和广义表
5.1 数组的定义
5.2 数组的顺序表示和实现
5.3 矩阵的压缩存储
5.3.1 特殊矩阵
5.3.2 稀疏矩阵
5.4 广义表的定义
5.1 数组的定义
数组-----线性表的扩展 A =(a0,a1,a2,…,an-1)
a00 a10 ┇ Am×n= ai0 ┇ am-1,0 a01 … a0j … a11 … a1j … ┇ ai2 … aij … ┇ am-1,2 … am-1,j … a0,n-1 a1,n-1 ai,n-1 am-1,n-1 α0 α1 ┇ Am×n= α i ┇ α m-1
Assign( &A, e, index1, ..., indexn) 赋值操作 初始条件:A是n维数组,e为元素变量,随后是n个下标值。 操作结果:若下标不超界,则将e的值赋给所指定的A的元 素,并返回OK。 对于数组来说一旦维数确定了,每个元素的下标确定了, 那么整个数组就确定了,这样的一个数组结构除了能改变 某元素的值,其他的不能再改变。
5.2 数组的顺序表示和实现
数组类型特点: 1) 只有引用型操作,没有加工型操作; 2) 数组是多维的结构,而存储空间是一个一维的结构。 有两种顺序映象的方式。
有两种顺序映像方法: 1)以行序为主序(行优先,先行后列):先存储行号较小 的元素,行号相同者先存储列号较小的元素;
数据结构5
重点和难点
重点是学习数组类型的定义及其存储表示. 重点是学习数组类型的定义及其存储表示. 数组类型的定义及其存储表示
知识点
数组的类型定义,数组的存储表示,特殊矩阵的压缩存储表示方法, 数组的类型定义,数组的存储表示,特殊矩阵的压缩存储表示方法, 随机稀疏矩阵的压缩存储表示方法. 随机稀疏矩阵的压缩存储表示方法.
A m×n m×n
a 00 a 10 = ... a m-1,0
a 01 a11 ...
a 02 a12 ...
a m-1,1 a m-1,2
... a 0,n-1 ... a1,n-1 ... ... ... a m-1,n-1
行向量
Data Structure
2010-1-2
n阶矩阵; 阶矩阵; 非零元都集中在以主对角线为中心的带状区域中. 所有的非零元都集中在以主对角线为中心的带状区域中 所有的非零元都集中在以主对角线为中心的带状区域中.
Data Structure 2010-1-2 Page 14
压缩存储——对称矩阵 对称矩阵 压缩存储
仅存储下 三角
a11 a12 …. … ….. a1n a21 a22 …….. ……. a2n …………………. an1 an2 ……..
A m×n m×n
a 00 a 10 = ... a m-1,0
a 01 a11 ...
a 02 a12 ...
a m-1,1 a m-1,2
... a 0,n-1 ... a1,n-1 ... ... ... a m-1,n-1
Data Structure
2010-1-2
Page 6
Assign(&A, e, index1, ..., indexn)
数据结构讲义第5章-数组和广义表
5.4 广义表
5)若广义表不空,则可分成表头和表尾,反之,一对表头和表尾 可唯一确定广义表 对非空广义表:称第一个元素为L的表头,其余元素组成的表称 为LS的表尾; B = (a,(b,c,d)) 表头:a 表尾 ((b,c,d)) 即 HEAD(B)=a, C = (e) D = (A,B,C,f ) 表头:e 表尾 ( ) TAIL(B)=((b,c,d)),
5.4 广义表
4)下面是一些广义表的例子; A = ( ) 空表,表长为0; B = (a,(b,c,d)) B的表长为2,两个元素分别为 a 和子表(b,c,d); C = (e) C中只有一个元素e,表长为1; D = (A,B,C,f ) D 的表长为4,它的前三个元素 A B C 广义表, 4 A,B,C , 第四个是单元素; E=( a ,E ) 递归表.
以二维数组为例:二维数组中的每个元素都受两个线性关 系的约束即行关系和列关系,在每个关系中,每个元素aij 都有且仅有一个直接前趋,都有且仅有一个直接后继. 在行关系中 aij直接前趋是 aij直接后继是 在列关系中 aij直接前趋是 aij直接后继是
a00 a01 a10 a11
a0 n-1 a1 n-1
a11 a21 ┇ a12 a22 ┇ ai2 ┇ … amj … amn … aij … ain … … a1j a2j … … a1n a2n β1 β2 ┇ βi ┇ βm
数据结构第五讲数组
数据结构
12
矩阵的压缩存储
矩阵的压缩存储策略: 为多个值相同的元素只分配一个存储空间;或
者对零元素不分配空间。
2020/1/6
数据结构
13
特殊矩阵: 指有许多值相同的元素或有许多零元素、且
值相同的元素或零元素的分布有一定规律的矩阵。 例子:
对称矩阵、三角矩阵和三对角矩阵等都属于 特殊矩阵。
2020/1/6
= LOC(0,0, …,0)+((b1×b2× ┅×bn-1)×i0
+( b2×b3× ┅×bn-1)×i1+ … bn-1×in-2+ in-1) )× L
= LOC(0,0, … ,0)+
n-2
( ik
n-1
bj in-1) L
k=0 j=k+1
2020/1/6
数据结构
8
要点归纳
2020/1/6
数据结构
3
数据结构中数组与高级程序设计语言中的数组区别:
高级程序设计语言中的数组用一组连 续有存储单元来表示表示,是数组的顺序 存储结构。
数组也可以用其它的存储表示。
其实也很少见
2020/1/6
数据结构
4
讨论:数组与线性表的区别与联系:
(1)数组是线性表的一个推广,而线性表是数组的一种特殊 情况 。
} } return(1); }
算法的执行时间为O(n×t)当非零元素个数t的量级为
m×n时,其执行时间便成为O(m×n2)
2020/1/6
数据结构
24
(2) 按照a.data中三元组的次序进行转置。转置后的元素不连 续存放,直接放到b.data中最终的位置上。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
0
0 …
…an,n-1
ann.
非零元素仅出现在主对角(aii,1≦i≦n)上,以及紧邻主对角线上面的那条 对角线上(aii+1,1≦i≦n-1)和紧邻主对角线下面的那条对角线上(ai+1 i,1≦i≦n-1)。显然,当∣i-j∣>1时,元素aij=0。
下面给出稀疏矩阵的三元组表存储表示的定义: # define maxsize 256 /* 最大非零元素个数 */ typedef struct /* 三元组类型 */ { int i,j; /* 该非零元素的行下标和列下标 */ datatype v; } triple; typedef struct /* 三元组表类型 */ { triple data[maxsize+1]; /* 三元组表存储空间 */ int mu,nu,tu; /* 矩阵的行数,列数和非零元素个数 */ } Tsmatrix; 其中data域中的非零元素的三元组是以行序为主序排列的。
5.3 矩阵的压缩存储
在科学与工程计算问题中,矩阵是一种常用的数学 对象,在高级语言编制程序时,简单而又自然的方法, 就是将一个矩阵描述为一个二维数组。矩阵在这种存储 表示之下,可以对其元素进行随机存取,各种矩阵运算 也非常简单,并且存储的密度为1。但是在矩阵中非零 元素呈某种规律分布或者矩阵中出现大量的零元素的情 况下,看起来存储密度仍为1,但实际上占用了许多单 元去存储重复的非零元素或零元素,这对高阶矩阵会造 成极大的浪费,为了节省存储空间,我们可以对这类矩 阵进行压缩存储:即为多个相同的非零元素只分配一个 存储空间;对零元素不分配空间。
i(i-1) Loc(aij)=Loc(a11)+[( +(j-1)]*l 2
二、三角矩阵
以主对角线划分,三角矩阵有上三角和下三角两种。上三角矩阵它的下 三角(不包括主对角线)中的元素均为常数。下三角矩阵正好相反,它的主 对角线上方均为常数。在大多数情况下,三角矩阵常数为零。
a11 0
a21 a22
第五章 数组
5.1 数组的定义 5.2 数组的顺序表示和实现 5.3 矩阵的压缩存储
5.3.1 5.3.2 特殊矩阵 稀疏矩阵
数组和广义表可看成是一种特殊的线性表,其特 殊在于,表中所在的元素本身也是一种线性表。
5.1 数组的定义
数组是我们最熟悉的数据类型,在早期的高级语 言中,数组是唯一可供使用的数据类型。由于数组中各 元素具有统一的类型,并且数组元素的下标一般具有固 定的上界和下界,因此,数组的处理比其它复杂的结构 更为简单。例如,二维数组: a11 a12 … a1n a21 a22 … a2n Amn= … … …… am1 am2 … amn
同理,一个维数组类型可以定义为其数据元素为多 维数组类型的一维数组类型。 数组一旦被定义,它的维数和维界就不再改变。因 此,除了结构的初始化和销毁之外,数组只有存取元素 和修改元素值的操作。
5.2
数组的顺序表示和实现
由于计算机的内存结构是一维的,因此用 一维内存来表示多维数组,就必须按某种次序将 数组元素排成一列序列,然后将这个线性序列存 放在存储器中。 又由于对数组一般不做插入和删除操作, 也就是说,数组一旦建立,结构中的元素个数和 元素间的关系就不再发生变化。因此,一般都是 采用顺序存储的方法来表示数组。
行列下标
0 1 2 3 4 5 6 7 8 i 6 0 0 2 2 3 4 5 5 j 7 2 0
非零元值 v 8 9 -3 1 12
0 0 12 9 0 0 0 0 3 0 0 0 M 0 0 24 0 0 18 0 0 15 0 0 7
0 0 0 0 0 14 0 0 0 0 0 0 0 0 0 0 67 0 0
三、对角矩阵 对角矩阵中,所有的非零元素集中在以主对角线为了中心的 带状区域中,即除了主对角线和主对角线相邻两侧的若干条对角 线上的元素之外,其余元素皆为零。
a11 a12 0
ቤተ መጻሕፍቲ ባይዱ
…………… . 0
0 0
a21 a22 a23 0 …………… 0 a32 a33 a34 0 ………
……………………………
ma[0].i,ma[0].j,ma[0].v分别存放 矩阵行列维数和非零元个数
5 14 2 24 1 18 0 3 ma 15 -7 三元组表所需存储单元个数为3(t+1) 其中t为非零元个数
• • • • • • • • • • • • • •
算法4.6 首先我们来建立一个三元组表: void creatsmatrix(datatype A1,Tsmatrix *A) /* A1为m行n列的稀疏矩阵,A为产生的相对的三元组表 */ { k=1; for(row=0;row<m;row++) /* 按行优先顺序扫描A1中的元素,不为0者存入A中 */ for(col=0;col<n;col++) if (A1[row][col]!=0) { A.data[k].i=row; A.data[k].j=col; A.data[k].v=A1[row][col]; k++;} A.mu=m;A.nu=n;A.tu=k-1; } /* 存入A中A1的行数,列数,非零元个数 */
通常有两种顺序存储方式:
⑴ 行优先顺序——将数组元素按行排列,第i+1个行向 量紧接在第i个行向量后面。以二维数组为例,按行优 先顺序存储的线性序列为: a11,a12,…,a1n,a21,a22,…a2n,……,am1,am2,…,amn 在PASCAL、C语言中,数组就是按行优先顺序存储的。 ⑵ 列优先顺序——将数组元素按列向量排列,第j+1个 列向量紧接在第j个列向量之后,A的m*n个元素按列优 先顺序存储的线性序列为: a11,a21,…,am1,a12,a22,…am2,……,an1,an2,…,anm 在FORTRAN语言中,数组就是按列优先顺序存储的。
0 ……..
0 ……..
0
0
………………….
an1 an2 an3……..
0
ann
按行序为主序:
a11 a21 a22 a31 a32 …... an1 …... k=1 2 3 4 5 n(n-1)/2+1
ann n(n+1)/2
i(i-1) Loc(aij)=Loc(a11)+[( +(j-1)]*l 2
5.3.2
稀疏矩阵
一、什么是稀疏矩阵?
简单说,设矩阵A中有s个非零元素,若s远远小于矩阵元素的 总数(即s≦m×n),则称A为稀疏矩阵。精确地说,设在的矩阵A 中,有s个非零元素。令 e=s/(m*n),称e为矩阵的稀疏因子。通常 0 12 9 0 0 0 0 认为e≦0.05时称之为稀疏矩阵。在存储稀疏矩阵时,为了节省存 储单元,很自然地想到使用压缩存储方法。但由于非零元素的分布 0 0 0 0 0 0 0 3 0 0 0 0 14 0 一般是没有规律的,因此在存储非零元素的同时,还必须同时记下 M 它所在的行和列的位置(i,j)。,一个三元组 唯一确定了 0 0 24(i,j,a 0 0ij)0 0 矩阵A的一个非零元素。因此,稀疏矩阵可由表示非零元素的三元 0 18 0 0 0 0 0 组及其行列数唯一确定。 15 0 0 7 0 0 0 67
…………………. …………………. am1 a mn a am2 …….. …….. a a
m1 m2
mn
Loc(a )=Loc( a11 )+[(j-1)m+(i-1)]*l Loc( ij a )=Loc( a ij 11)+[(i-1)n+(j-1)]*l
m*n-1 m*n-1
a mn
按上述两种方式顺序存储的数组,只要知道开始结点的存放地址 (即基地址)、维数和每维的上、下界,以及每个数组元素所占用的 单元数,就可以将数组元素的存放地址表示为其下标的线性函数。因 此,数组中的任一元素可以在相同的时间内存取,即顺序存储的数组 是一个随机存取结构。 例如,二维数组Amn按“行优先顺序”存储在内存中,假设每个元 素占用d个存储单元。 元素aij的存储地址应是数组的基地址加上排在 aij前面的元素所占 用的单元数。因为aij位于第i行、第j列,前面i-1行一共有(i-1) ×n 个元素,第i行上aij前面又有j-1个元素,故它前面一共有(i-1) ×n+j-1个元素,因此,aij的地址计算函数为: LOC(aij)=LOC(a11)+[(i-1)*n+j-1]*d 上述讨论均是假设数组各维的下界是1,更一般的二维数组是 A[c1..d1,c2..d2],这里c1,c2不一定是1。aij前一共有i-c1行,二维数 组一共有d2-c2+1列,故这i-c1行共有(i-c1)*(d2-c2+1)个元素,第i行 上aij前一共有j-c2个元素,因此,aij的地址计算函数为: LOC(aij)=LOC(ac1c2)+[(i-c1)*(d2-c2+1)+j-c2)]*d
按列序为主序存放 按行序为主序存放
0 1 1
a11 a 11 a21 a
21
a12 …….. …….. a a1n a 12 1n a22 …….. …….. a a2n a 22 2n
n-1 m-1 m n
a11 a21 12 ……. am1 1n a12 21 a22 …….. am2 2n ………. a1n m1 a2n m2 ……..
2.有关操作
矩阵的转置
一个m×n的矩阵A,它的转置B是一个n×m的矩阵,那么 a[i][j]=b[j][i],0≦i≦m-1,0≦j≦n-1,即A的行是B的列,A 的列是B的行。 将A转置为B,就是将A的三元组表a.data置换为表B的三元组 表b.data,假设A是按行优先顺序存储,如果只是简单地交换 a.data中i和j的内容,那么得到的b.data将是一个按列优先顺序 存储的稀疏矩阵B,要得到按行优先顺序存储的b.data,就必须 重新排列三元组的顺序。 由于A的列是B的行,因此,按a.data的列序转置,所得到的 转置矩阵B的三元组表b.data必定是按行优先存放的。