数组之三种矩阵
文字描述
矩阵的压缩:对于某些特殊的矩阵来说,非零元素较少,大部分元素为0,采用某种算法,将非零元素存储在一位数组里以达到节省存储空间的目的的过程,称为矩阵的压缩
矩阵的还原:将压缩后的数组还原成原始矩阵的过程
1、对角矩阵
①矩阵介绍
所谓对角矩阵:
矩阵中的所有非零元素都集中在以主对角线为中心的带状区域中,
即除了主对角线上和直接在主对角线上下若干条对角线上的元素外,其余元素均为零。
这样的矩阵称为半带宽为d的带状矩阵,带宽是2*d+1,d为直接在对角线上下方不为0的对角线数
② 矩阵压缩原理
对于n阶2d+1对角矩阵,只需要存放对角线区域内 n*(2*d+1)-d*(d+1)个非零元素
为了简便运算,认为每一行都有2*d+1个元素,若少于2*d+1个元素,则添零补齐。
因为非零元素都在主对角线元素的左右两侧,
那么只要在矩阵的每一行的主对角线元素的两侧分别 “凑够” d个元素即可,
如果该元素 “不在" 矩阵内部,则补零,如果“在”矩阵内部,则存储到一维数组中即可
2、对称矩阵
① 矩阵介绍
对称矩阵 array[ i ][ j ]=array[ j ][ i ] 所以对于相同的元素只保存一个
②矩阵压缩的原理
压缩成一个一维数组后 array [ i ] [ j] =array [ j ] [ i ]
s [ k ] = i * ( i + 1 ) / 2 + j = j * ( j + 1 ) / 2 + i ;
对于一个n阶的矩阵而言,压缩后一维空间的数目为 n*(n+1)/2;
3、三角矩阵
① 矩阵介绍
所谓三角矩阵:
整个矩阵只有主对角线及主对角线以上(或以下)为非零元素。
下三角形矩阵:主对角线及主对角线以下为非零元素
上三角形矩阵:主对角线及主对角线以上为非零元素
很显然对于一个n阶的矩阵而言,压缩后一维空间的数目为n*(n+1)/2;(等差数列求和)
(以下以下三角为例进行分析)
② 矩阵压缩的原理
根据该矩阵的性质,很容易得出结论
很显然第一行一个元素,第二行两个元素,依次类推。。。
代码实现
1、对角矩阵
2、对称矩阵
3、三角矩阵
提醒:各种矩阵实现源码下载:
http://www.cnblogs.com/tanlon/p/4155687.html