特殊矩阵的压缩存储(对称矩阵,三角矩阵,三对角矩阵,稀疏矩阵)

目录

1.数组的存储结构

1.---维数组

各数组元素大小相同,且物理上连续存放。

数组元素a[i]的存放地址= 起始地址 L O C + i ∗ s i z e o f ( E l e m T y p e ) ( 0 < i < 10 ) 起始地址LOC+i * sizeof(ElemType)(0<i<10) 起始地址LOC+i∗sizeof(ElemType)(0<i<10)

2.二维数组

1.行优先存储

M行N列的二维数组b[M][N]中,若按行优先存储

则b[i][j]的存储地址= L O C + ( i ∗ N + j ) ∗ s i z e o f ( E l e m T y p e ) LOC + (i*N+ j) * sizeof(ElemType) LOC+(i∗N+j)∗sizeof(ElemType)

2.列优先存储

M行N列的二维数组b[M][N]中,若按列优先存储

则b[i][i]的存储地址= L O C + ( j ∗ M + i ) ∗ s i z e o f ( E l e m T y p e ) LOC+ ( j*M+i ) * sizeof(ElemType) LOC+(j∗M+i)∗sizeof(ElemType)

2.特殊矩阵

1.对称矩阵

若n阶方阵中任意一个元素aij,都有 a i j = a j i aij=aji aij=aji则该矩阵为对称矩阵

压缩存储策略:只存储主对角线+下三角区(或主对角线+上三角区)

1.行优先存储

1.下三角区

策略:只存储主对角线+下三角区

①存储的数组长度: ( 1 + n ) ∗ n / 2 (1+n)*n/2 (1+n)∗n/2

②矩阵下标 a i j aij aij与一维数组下标k的映射关系: k = i ( i − 1 ) 2 + j − 1 , i > = j k=\frac{i(i-1)}{2}+j-1,i>=j k=2i(i−1)+j−1,i>=j
2.上三角区

根据对称矩阵的性质: a i j = a j i aij = aji aij=aji:
k = j ( j − 1 ) 2 + i − 1 , i < j k=\frac{j(j-1)}{2}+i-1,i<j k=2j(j−1)+i−1,i<j

2.三角矩阵

压缩存储策略:按行优先原则将橙色区元素存入一维数组中。并在最后一个位置存储常量c

1.上三角矩阵

除了主对角线和上三角区,其余的元素都相同。

按照行优先的原则,映射关系: k = ( i − 1 ) ( 2 n − i + 2 ) 2 + j − i , i < = j ( 上三角区和主对角线元素 ) k=\frac{(i-1)(2n-i+2)}{2}+j-i,i<=j(上三角区和主对角线元素) k=2(i−1)(2n−i+2)+j−i,i<=j(上三角区和主对角线元素)
k = n ( n + 1 ) 2 , i > j ( 下三角区元素 ) k = \frac{n(n+1)}{2},i>j(下三角区元素) k=2n(n+1),i>j(下三角区元素)

2.下三角矩阵

除了主对角线和下三角区,其余的元素都相同。

按照行优先的原则,映射关系: k = i ( i − 1 ) 2 + j − 1 , i > = j ( 下三角区和主对角线元素 ) k=\frac{i(i-1)}{2}+j-1,i>=j(下三角区和主对角线元素) k=2i(i−1)+j−1,i>=j(下三角区和主对角线元素)
k = n ( n + 1 ) 2 , i < j ( 上三角区元素 ) k = \frac{n(n+1)}{2},i<j(上三角区元素) k=2n(n+1),i<j(上三角区元素)

3.三对角矩阵(带状矩阵)

三对角矩阵,又称带状矩阵: 当 ∣ i − j ∣ > 1 时,有 a i j = 0 ( 1 < = i , j ≤ n ) 当|i -j|>1时,有aij=0 (1<=i, j ≤n) 当∣i−j∣>1时,有aij=0(1<=i,j≤n)

压缩存储策略:按行优先((或列优先)原则,只存储带状部分。

①已知aij求数组下标k:

前i-1行共 3 ( i − 1 ) − 1 3(i-1)-1 3(i−1)−1个元素

aij是i行第 j − i + 2 j-i+2 j−i+2个元素

aij是第 2 i + j − 2 2i+j-2 2i+j−2个元素
k = 2 i + j − 3 k=2i+j-3 k=2i+j−3(数组下标从0开始)

②若已知数组下标k,如何得到i,j?

即第k+1个元素:
i = 「 ( k + 2 ) / 3 ] i =「(k+2)/3] i=「(k+2)/3](向上取整)

由 k = 2 i + j − 3 k=2i+j-3 k=2i+j−3得,
j = k − 2 i + 3 j=k-2i+3 j=k−2i+3

4.稀疏矩阵

稀疏矩阵:非零元素远远少于矩阵元素的个数。

压缩存储策略:

①顺序存储:三元组<行,列,值>,会失去随机存储的特性。

例如:

对应的三元组为:

②链式存储:十字链表法

结点说明:

相关推荐
xiaohanbao098 分钟前
day30 python 模块、包与库的高效使用指南
人工智能·python·学习·算法
持之以恒的天秤11 分钟前
哈希表和哈希函数
算法·哈希算法·散列表
摄殓永恒12 分钟前
出现的字母个数
数据结构·c++·算法
exe45229 分钟前
力扣每日一题5-18
java·算法·leetcode
点云SLAM1 小时前
C++中聚合类(Aggregate Class)知识详解和注意事项
c++·算法·c++20·c++学习·聚合类·面向对象设计、·c++高级应用
YuforiaCode1 小时前
LeetCode 219.存在重复元素 II
算法·leetcode·职场和发展
CodeQingqing1 小时前
C语言练手磨时间
c语言·数据结构·算法
jndingxin2 小时前
OpenCV CUDA 模块中的矩阵算术运算-----在频域(复数频谱)中执行逐元素乘法并缩放的函数mulAndScaleSpectrums()
opencv·计算机视觉·矩阵
卡尔曼的BD SLAMer2 小时前
计算机视觉与深度学习 | Python实现EMD-SSA-VMD-LSTM时间序列预测(完整源码和数据)
python·深度学习·算法·cnn·lstm
yu_anan1112 小时前
Denoising Score Matching with Langevin Dynamics
算法·机器学习·概率论