数组和稀疏矩阵精品文稿.ppt
《数组和稀疏矩阵精品文稿.ppt》由会员分享,可在线阅读,更多相关《数组和稀疏矩阵精品文稿.ppt(48页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数组和稀疏矩阵数组和稀疏矩阵第1页,本讲稿共48页5.1.1 5.1.1 数组的基本概念数组的基本概念 数数组组是是n(n1)个个相相同同类类型型数数据据元元素素a1,a2,an构构成成的的有限序列有限序列,且该有限序列存储在一块地址连续的内存单元中。且该有限序列存储在一块地址连续的内存单元中。由由此此可可见见,数数组组的的定定义义类类似似于于采采用用顺顺序序存存储储结结构构的的线线性表。性表。第2页,本讲稿共48页数组具有以下性质:数组具有以下性质:(1)数数组组中中的的数数据据元元素素数数目目固固定定。一一旦旦定定义义了了一一个个数组数组,其数据元素数目不再有增减变化。其数据元素数目不再有
2、增减变化。(2)数组中的数据元素具有相同的数据类型。数组中的数据元素具有相同的数据类型。(3)数数组组中中的的每每个个数数据据元元素素都都和和一一组组惟惟一一的的下下标标值值对对应。应。(4)数数组组是是一一种种随随机机存存储储结结构构。可可随随机机存存取取数数组组中中的的任意数据元素。任意数据元素。第3页,本讲稿共48页5.1.2 5.1.2 数组的存储结构数组的存储结构 在在一一维维数数组组中中,一一旦旦a1的的存存储储地地址址LOC(a1)确确定定,并并假假设设每每个个数数据据元元素素占占用用k个个存存储储单单元元,则则任任一一数数据据元元素素ai的的存储地址存储地址LOC(ai)就可由
3、以下公式求出:就可由以下公式求出:LOC(ai)=LOC(a1)+(i-1)*k(0in)上上式式说说明明,一一维维数数组组中中任任一一数数据据元元素素的的存存储储地地址址可可直直接接计计算算得得到到,即即一一维维数数组组中中任任一一数数据据元元素素可可直直接接存存取取,因因此此,一一维维数数组组是是一一种种随随机机存存储储结结构构。同同样样,二二维维及及多多维维数数组也满足随机存储特性。组也满足随机存储特性。第4页,本讲稿共48页对于一个对于一个m m行行n n列的二维数组列的二维数组A Amnmn,有:有:将将Am*n简记为简记为A,A是这样的一维数组:是这样的一维数组:A=(a1,a2,
4、ai,am)其中其中,ai=(ai,1,ai,2,ai,n)(1jm)。第5页,本讲稿共48页 显显然然,二二维维数数组组同同样样满满足足数数组组的的定定义义。一一个个二二维维数数组组可可以以看看作作是是每每个个数数据据元元素素都都是是相相同同类类型型的的一一维维数数组组的的一一维维数数组组。以以此此类类推推,任任何何多多维维数数组组都都可可以以看看作作一一个个线线性性表表,这这时时线线性性表表中中的的每每个个数数据据元元素素也也是是一一个个线性表。多维数组是线性表的推广。线性表。多维数组是线性表的推广。第6页,本讲稿共48页 对对于于二二维维数数组组来来说说,由由于于计计算算机机的的存存储储
5、结结构构是是线线性性的的,如如何何用用线线性性的的存存储储结结构构存存放放二二维维数数组组元元素素就就有有一一个个行列次序排放问题。行列次序排放问题。以以行行序序为为主主序序的的存存储储方方式式:即即先先存存储储第第1行行,然然后后紧紧接接着着存存储储第第2行行,最最后后存存储储第第m行行。此此时时,二二维维数数组组的的线线性性排排列列次次序为:序为:a1,1,a1,2,a1,n,a2,1,a2,2,a2,n,am,1,am,2,am,n第7页,本讲稿共48页 对对一一个个已已知知以以行行序序为为主主序序的的计计算算机机系系统统中中,当当二二维维数数组组第第一一个个数数据据元元素素a1,1的的
6、存存储储地地址址LOC(a1,1)和和每每个个数数据据元元素素所所占占用用的的存存储储单单元元k确确定定后后,则则该该二二维维数数组组中中任任一一数数据据元元素素ai,j的的存储地址可由下式确定:存储地址可由下式确定:LOC(ai,j)=LOC(a1,1)+(i-1)*n+(j-1)*k 其中其中n为列数。为列数。第8页,本讲稿共48页 同理可推出在以列序为主序的计算机系统中有:同理可推出在以列序为主序的计算机系统中有:LOC(ai,j)=LOC(a1,1)+(j-1)*m+(i-1)*k 其中其中m为行数。为行数。第9页,本讲稿共48页 例例5.1 对二维数组对二维数组float a54计算
7、:计算:(1)数组数组a中的数组元素数目;中的数组元素数目;(2)若若数数组组a的的起起始始地地址址为为2000,且且每每个个数数组组元元素素长长度度为为32位位(即即4个字节个字节),数组元素数组元素a32的内存地址。的内存地址。第10页,本讲稿共48页 解解:由由于于C语语言言中中数数组组的的行行、列列下下界界均均为为0,该该数数组组行行上上界界为为5-1=4,列列上上界界为为4-l=3,所所以以该该数数组组的的元元素数目共有素数目共有(4-0+1)*(3-0+1)=5*4=20个。个。又由于又由于C语言采用行序为主序的存储方式语言采用行序为主序的存储方式,则有:则有:LOC(a3,2)=
8、LOC(a0,0)+(i*n+j)*k =2000+(3*4+2)*4=2056第11页,本讲稿共48页5.1.3 特殊矩阵的压缩存储特殊矩阵的压缩存储 特特殊殊矩矩阵阵是是指指非非零零元元素素或或零零元元素素的的分分布布有有一一定定规规律律的的矩矩阵阵,为为了了节节省省存存储储空空间间,特特别别是是在在高高阶阶矩矩阵阵的的情情况况下下,可可以以利利用用特特殊殊矩矩阵阵的的规规律律,对对它它们们进进行行压压缩缩存存储储,也也就就是是说说,使使多多个个相相同同的的非非零零元元素素共共享享同同一一个个存存储储单单元元,对零元素不分配存储空间。对零元素不分配存储空间。特特殊殊矩矩阵阵的的主主要要形形
9、式式有有对对称称矩矩阵阵、对对角角矩矩阵阵等等,它它们们都是方阵都是方阵,即行数和列数相同。即行数和列数相同。第12页,本讲稿共48页 1.对称矩阵的压缩存储对称矩阵的压缩存储 若若 一一 个个 n阶阶 方方 阵阵Ann中中 的的 元元 素素 满满 足足ai,j=aj,i(0i,jn-1),则称其为则称其为n阶阶对称矩阵对称矩阵。由由于于对对称称矩矩阵阵中中的的元元素素关关于于主主对对角角线线对对称称,因因此此在在存存储储时时可可只只存存储储对对称称矩矩阵阵中中上上三三角角或或下下三三角角中中的的元元素素,使使得得对对称称的的元元素素共共享享一一个个存存储储空空间间。这这样样,就就可可以以将将
10、n2个个元元素素压压缩缩存存储储到到个个元元素素的的空空间间中中。不不失失一一般般性性,我我们们以以行行序序为为主主序存储其下三角序存储其下三角(包括对角线包括对角线)的元素。的元素。第13页,本讲稿共48页 n2个元素个元素 n(n+1)/2个元素个元素 A0.n-1,0.n-1 B0.n(n+1)/2-1 aij bkk=+j ij+i ij第14页,本讲稿共48页上三角矩阵:上三角矩阵:k=+j i ij时时ij时时第15页,本讲稿共48页下三角矩阵:下三角矩阵:k=ij时时ij时时第16页,本讲稿共48页 2.对角矩阵的压缩存储对角矩阵的压缩存储 若若一一个个n阶阶方方阵阵A满满足足其
11、其所所有有非非零零元元素素都都集集中中在在以以主主对对角角线线为为中中心心的的带带状状区区域域中中,则则称称其其为为n阶阶对对角角矩矩阵阵。其其主主对对角角线线上上下下方方各各有有b条条次次对对角角线线,称称b为为矩矩阵阵半半带带宽宽,(2b+1)为为矩矩阵阵的的带带宽宽。对对于于半半带带宽宽为为b(0b(n-1)/2)的的对对角角矩矩阵阵,其其|i-j|b的的元元素素ai,j不不为为零零,其其余余元元素素为为零零。下下图图所所示示是是半半带带宽为宽为b的对角矩阵示意图。的对角矩阵示意图。第17页,本讲稿共48页 半带宽为半带宽为b b的对角矩阵的对角矩阵第18页,本讲稿共48页当当b1时称为
12、三对角矩阵。时称为三对角矩阵。其压缩地址计算公式如下:其压缩地址计算公式如下:k=2i+j A B aij bk第19页,本讲稿共48页 例例5.2 按按行行优优先先顺顺序序和和按按列列优优先先顺顺序序列列出出四四维维数组数组A2222所有元素在内存中的存储次序。所有元素在内存中的存储次序。第20页,本讲稿共48页 解:解:按行优先的存储次序按行优先的存储次序:A0000,A0001,A0010,A0011,A0100,A0101,A0110,A0111,A1000,A1001,A1010,A1011,A1100,A1101,A1110,A1111第21页,本讲稿共48页 按列优先的存储次序按
13、列优先的存储次序:A0000,A1000,A0100,A1100,A0010,A1010,A0110,A1110,A0001,A1001,A0101,A1101,A0011,A1011,A0111,A1111第22页,本讲稿共48页 例例5.3 对对于于二二维维数数组组Amn,其其中中m80,n80,先先读读入入m和和n,然然后后读读该该数数组组的的全全部部元元素素,对对如如三三种种情情况况分分别别编编写相应函数写相应函数:(1)求数组求数组A靠边元素之和靠边元素之和;(2)求求从从A00开开始始的的行行、列列互互不不相相邻邻的的各各元元素素之之和和;(3)当当m=n时时,分分别别求求两两条条
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数组 稀疏 矩阵 精品 文稿
限制150内