《第五章数组优秀PPT.ppt》由会员分享,可在线阅读,更多相关《第五章数组优秀PPT.ppt(22页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第五章数组第五章数组第一页,本课件共有22页2数组的定义数组的定义数组结构可以简单地定义为:若线性表中的数组结构可以简单地定义为:若线性表中的数据元素为非结构的简单元素,则称为一维数组,数据元素为非结构的简单元素,则称为一维数组,即为向量;若一维数组中的数据元素又是一维数即为向量;若一维数组中的数据元素又是一维数组结构,则称为二维数组;依次类推,若二维数组结构,则称为二维数组;依次类推,若二维数组中的元素又是一个一维数组结构,则称作三维组中的元素又是一个一维数组结构,则称作三维数组。数组。结论:线性表结构是数组结构的一个特例,而结论:线性表结构是数组结构的一个特例,而数组结构又是线性表结构的扩
2、展。数组结构又是线性表结构的扩展。第二页,本课件共有22页3()()()()()()()()()二维数组二维数组数组数组A A可以看成一个线性表:可以看成一个线性表:A=(0A=(0,1 1,.,k)k)(k=m-1k=m-1或或n-1n-1)其中每一个数据元素其中每一个数据元素i i 是由第是由第i i行行元素组成的一维数组,即一个行元素组成的一维数组,即一个行向量的线性表。向量的线性表。i=(ai0 i=(ai0,ai1 ai1,.,ai,n-1 ai,n-1)0im-1)0im-1或或jj是由第是由第j j列元素组成的一维列元素组成的一维数组,即一个列向量的线性表。数组,即一个列向量的线
3、性表。第三页,本课件共有22页4数组的特点及运算数组的特点及运算数组特点数组特点l数组结构固定数组结构固定l数据元素同构数据元素同构数组运算数组运算l给定一组下标,存取相应的数据元素给定一组下标,存取相应的数据元素l给定一组下标,修改数据元素的值给定一组下标,修改数据元素的值l数组一般不做插入或删除操作数组一般不做插入或删除操作第四页,本课件共有22页5次序约定次序约定l以行序为主序l以列序为主序a11a12.a1na21a22.a2nam1am2.amn.Loc(aij)=Loc(a11)+(i-1)n+(j-1)*l按行序为主序存放按行序为主序存放amn.am2am1.a2n.a22a21
4、a1n.a12a1101n-1m*n-1n数数组组的的顺顺序序存存储储结结构构按列序为主序存放按列序为主序存放01m-1m*n-1mamn.a2na1n.am2.a22a12am1.a21a11a11a12.a1na21a22.a2nam1am2.amn.Loc(aij)=Loc(a11)+(j-1)m+(i-1)*l第五页,本课件共有22页6矩阵的压缩存储方法矩阵的压缩存储方法压缩存储压缩存储是指为多个值相同的元素只分配一个是指为多个值相同的元素只分配一个存储空间;对零元素不分配空间。存储空间;对零元素不分配空间。第六页,本课件共有22页7a11a12.a1na21a22.a2nan1an2
5、.ann.a11a21a22a31a32an1ann.k=01234n(n-1)/2n(n+1)/2-1按行序为主序:按行序为主序:对称矩阵的压缩存储方法对称矩阵的压缩存储方法第七页,本课件共有22页8a1100.0a21a220.0an1an2an3.ann.0Loc(aij)=Loc(a11)+(+(j-1)*li(i-1)2a11a21a22a31a32an1ann.k=01234n(n-1)/2n(n+1)/2-1按行序为主序:按行序为主序:三角矩阵的压缩存储方法三角矩阵的压缩存储方法第八页,本课件共有22页9a11a120.0a21a22a230000an-1,n-2an-1,n-1
6、an-1,n00an,n-1ann.0a32a33a3400Loc(aij)=Loc(a11)+3*(i-1)-1+j-i+1 =Loc(a11)+2(i-1)+(j-1)a11a12a21a22a23ann-1ann.k=01234n(n-1)/2n(n+1)/2-1按行序为主序:按行序为主序:对角矩阵的压缩存储方法对角矩阵的压缩存储方法第九页,本课件共有22页10M由由(1,2,12),(1,3,9),(3,1,-3),(3,6,14),(4,3,24),(5,2,18),(6,1,15),(6,4,-7)和矩阵维数(和矩阵维数(6,7)唯一确定)唯一确定定义:定义:非零元较零元少,且分布
7、没有一定规律的矩阵非零元较零元少,且分布没有一定规律的矩阵压缩存储原则:压缩存储原则:只存矩阵的行列维数和每个非零元的行列下只存矩阵的行列维数和每个非零元的行列下标及其值标及其值稀疏矩阵稀疏矩阵第十页,本课件共有22页11三元组表所需存储单元个数为3(t+1)其中t为非零元个数678121213931-3361443245218611564-7maijv012345678ma0.i,ma0.j,ma0.v分别存放矩阵行列维数和非零元个数行列下标非零元值稀疏矩阵的三元组表示法#define MAX 10 typedef struct int i,j;elemtype v;node;typedef
8、 struct int mu,nu,tu;node dataMAX;mat;mu,nu,tu分别存放矩阵行列维数和非零元个数第十一页,本课件共有22页12 算法思路:算法思路:将两个矩阵的行数和列数相互交换;将两个矩阵的行数和列数相互交换;将每个三元组中的将每个三元组中的i和和j相互调换;相互调换;重排三元组之间的次序便可实现矩阵的转重排三元组之间的次序便可实现矩阵的转置,即使置,即使b.data中的三元组以中的三元组以B的行(即的行(即A的的列)为主序依次排列。列)为主序依次排列。稀疏矩阵的转置运算稀疏矩阵的转置运算第十二页,本课件共有22页13 算法实现思想(算法算法实现思想(算法2.16
9、):):按照矩阵按照矩阵A的列序来进行转置运算。也就是首先的列序来进行转置运算。也就是首先寻找寻找a.data中的第列的所有三元组,将其中的第列的所有三元组,将其(i,j,v)改为改为(j,i,v)后依次存放到后依次存放到b.data中,作为转置矩中,作为转置矩阵阵B的第行的非零元所对应的三元组。然后的第行的非零元所对应的三元组。然后在在a.data中寻找第列的所有三元组,将其中寻找第列的所有三元组,将其(i,j,v)改为改为(j,i,v)后依次存放在后依次存放在b.data中,作为转置矩中,作为转置矩阵阵B的第行的非零元所对应的三元组,依次类的第行的非零元所对应的三元组,依次类推。推。稀疏矩
10、阵的转置运算的实现稀疏矩阵的转置运算的实现第十三页,本课件共有22页14678121213931-3361443245218611564-7ijv012345678ma76813-3161521122518319342446-76314ijv012345678mbkppppppppkkkkppppppppcol=1col=2说明:说明:p p是算法中的是算法中的amam,k k是算法中的是算法中的bnbn第十四页,本课件共有22页15lmat*zzjz(mat*a)lintam.bn.col;lmat*b;/*转置后的矩阵转置后的矩阵b*/lb=(mat*)malloc(sizeof(mat)
11、;lb.nu=a.mu;b.mu=a.nu;b.tu=a.tu;/*a,b矩阵行、列交换矩阵行、列交换*/lbn=0;lfor(col=1;col=a.nu;col+)/*按按a的列序转置的列序转置*/lfor(am=1;am=a.tu;am+)/*扫描整个三元组表扫描整个三元组表*/lif(a.dataam.j=col)/*列号为列号为col是转置是转置*/lb.databn.i=a.dataam.j;lb.databn.j=a.dataam.i;lb.databn.v=a.dataam.v;lbn+;/*b.data中的结点序号加中的结点序号加1*/llreturnb;/*返回转置矩阵的指
12、针返回转置矩阵的指针*/l第十五页,本课件共有22页16算法算法2.16的主要耗费时间是在的主要耗费时间是在col和和am的两重循的两重循环中,所以算法的时间复杂度为环中,所以算法的时间复杂度为O(nu.tu),(nu表表示示a.nu,tu表示表示a.tu),即和即和A的列数与非零元素的个的列数与非零元素的个数的乘积成正比。数的乘积成正比。当非零元个数值当非零元个数值tu=m*n时,(时,(m、n分别表示数分别表示数组的行列数)算法组的行列数)算法2.16的时间复杂度成为的时间复杂度成为O(m*n2)。因此算法因此算法2.16的时间复杂度比的时间复杂度比O(m*n)还差。一般还差。一般上述转置
13、算法只适用于当上述转置算法只适用于当tumu*nu的情况。的情况。稀疏矩阵的转置运算算法分析稀疏矩阵的转置运算算法分析第十六页,本课件共有22页17十字链表的结点类十字链表的结点类型定义如下:型定义如下:typedefstructnodeinti,j,v;structnode*down,*right;szjd;稀疏矩阵的十字链表表示法第十七页,本课件共有22页18稀疏矩阵的十字链表表示法(续)第十八页,本课件共有22页19算法步骤:算法步骤:(1)将行、列指针数组置空。假设)将行、列指针数组置空。假设m,n分别是行指分别是行指针和列指针数组,针和列指针数组,hs,ls是指向存放矩阵行数和列是指
14、向存放矩阵行数和列数变量的指针变量。数变量的指针变量。(2)输入三元组,若行下标或列下标为输入三元组,若行下标或列下标为0时,则表时,则表示输入完毕,算法结束,否则生成示输入完毕,算法结束,否则生成p结点,并把结点,并把行、列、值域分别置为行、列、值域分别置为x,y,z。(3)把)把p结点插入到第结点插入到第x行链表中。行链表中。(4)把)把p结点插入到第结点插入到第y列链表中转向步骤列链表中转向步骤2。十字链表的建立算法第十九页,本课件共有22页20lszlbcreate(szjd*m,szjd*n,int*hs,int*ls)lintx,y,z,ms,ns;lintk=0;lszjd*p,
15、*q,*s;lms=ns=0;lscanf(“%d,%d”,&ms,&ns);lfor(k=0;kms;i+)lmk=NULL;lfor(;kms)|(yns)lcontinue;ls=(szjd*)malloc(sizeof(szjd);ls-i=x;s-j=y;s-v=z;ls-right=s-down=NULL;lq=NULL;lp=mx-1;lwhile(p!=NULL)&(yp-j)lq=p;p=p-right;lif(p=NULL)lif(q=NULL)mx-1=s;lelseq-right=s;lelseif(y=p-j)lp-v=z;free(s);continue;lelse
16、s-right=p;q-right=s;lq=NULL;p=ny-1;lwhile(p!=NULL)&(xp-i)lq=p;p=p-down;lif(p=NULL)lif(q=NULL)lny-1=s;lelseq-down=s;lelses-down=p;q-down=s;ll第二十页,本课件共有22页第二章第二章 线性表线性表内容提要内容提要 1 1、线性表的定义、逻辑结构特点及基本运算、线性表的定义、逻辑结构特点及基本运算2 2、线性表的顺序存储结构及基本运算、线性表的顺序存储结构及基本运算3 3、线性表的链式存储结构及基本运算线性表的链式存储结构及基本运算4 4、数组的逻辑结构定义及其存储方式数组的逻辑结构定义及其存储方式5 5、线性表的应用示例线性表的应用示例第二十一页,本课件共有22页22l线性表的逻辑结构、物理结构、基本运算及线性表的逻辑结构、物理结构、基本运算及运算实现的算法。运算实现的算法。l顺序表上的插入和删除算法及链表的建立、顺序表上的插入和删除算法及链表的建立、查找、插入和删除算法。查找、插入和删除算法。l线性表的典型算法的应用及解决问题的方线性表的典型算法的应用及解决问题的方法。法。l数组的压缩存储及运算数组的压缩存储及运算本章要点本章要点第二十二页,本课件共有22页