加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

【数据结构】对称矩阵及对称矩阵的压缩存储

发布时间:2020-12-15 05:58:47 所属栏目:安全 来源:网络整理
导读:对称矩阵: 设一个N*N的方阵A,A中任意元素Aij,当且仅当Aij == Aji(0 = i = N-1 0 = j = N-1),则矩阵A是对称矩阵。以矩阵的对角线为分隔,分为上三角和下三角。 如下面矩阵: 650) this.width=650;" src="http://img.jb51.cc/vcimg/static/loading.png" st

对称矩阵:


设一个N*N的方阵A,A中任意元素Aij,当且仅当Aij == Aji(0 <= i <= N-1 &&0 <= j <= N-1),则矩阵A是对称矩阵。以矩阵的对角线为分隔,分为上三角和下三角。


如下面矩阵:

spacer.gif

wKioL1cNhDTx1gApAAAO50iPSO8800.png

spacer.gif

对称矩阵压缩存储时只需要存储i*(i+1)/2个数据。


对称矩阵与压缩矩阵的关系是:

对称矩阵SymmetricMatrix[i][j] =压缩矩阵Array(i*(i+1)/2+j)。


spacer.gif

下面我实现一下对称矩阵存储在压缩矩阵以及将压缩矩阵中的元素还原成对称矩阵打印出来的代码。

代码如下:


#include<iostream>
usingnamespacestd;
template<classT>
classSymmtrixMatrix
{
public:
SymmtrixMatrix(T*a,size_tsize)
:_a(newT[size*(size+1)/2]),_size(size*(size+1)/2)
{
for(inti=0;i<size;i++)
{
for(intj=0;j<size;j++)
{
if(i>=j)
{
//将对称矩阵转换为压缩矩阵
_a[i*(i+1)/2+j]=a[i*size+j];
}

}
}
}
//压缩矩阵的访问打印
voidPrint(size_tsize)
{
for(inti=0;i<size;i++)
{
for(intj=0;j<size;j++)
{
introw=i;
intcol=j;
if(row<col)
{
swap(row,col);
}
cout<<_a[row*(row+1)/2+col]<<"";

}
cout<<endl;
}
cout<<endl;
}

private:
T*_a;
size_t_size;//即n,对称矩阵为方阵
};

voidTest()
{
inta[5][5]={
{0,1,2,3,4},{1,3},{2,2},{3,1},{4,0},};

SymmtrixMatrix<int>sm((int*)a,5);
sm.Print(5);

}

intmain()
{
Test();
system("pause");
return0;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读