对称矩阵:
设一个N*N的方阵A,A中任意元素Aij,当且仅当Aij == Aji(0 <= i <= N-1 &&0 <= j <= N-1),则矩阵A是对称矩阵。以矩阵的对角线为分隔,分为上三角和下三角。
如下面矩阵:
对称矩阵压缩存储时只需要存储i*(i+1)/2个数据。
对称矩阵与压缩矩阵的关系是:
对称矩阵SymmetricMatrix[i][j] =压缩矩阵Array(i*(i+1)/2+j)。
下面我实现一下对称矩阵存储在压缩矩阵以及将压缩矩阵中的元素还原成对称矩阵打印出来的代码。
代码如下:#include
usingnamespacestd;
template
classSymmtrixMatrix
{
public:
SymmtrixMatrix(T*a,size_tsize)
:_a(newT[size*(size+1)/2])
,_size(size*(size+1)/2)
{
for(inti=0;i
{
for(intj=0;j
{
if(i>=j)
{
//将对称矩阵转换为压缩矩阵
_a[i*(i+1)/2+j]=a[i*size+j];
}
}
}
}
//压缩矩阵的访问打印
voidPrint(size_tsize)
{
for(inti=0;i
{
for(intj=0;j
{
introw=i;
intcol=j;
if(row
{
swap(row,col);
}
cout<
}
cout<
}
cout<
}
private:
T*_a;
size_t_size;//即n,对称矩阵为方阵
};
voidTest()
{
inta[5][5]={
{0,1,2,3,4},
{1,0,1,2,3},
{2,1,0,1,2},
{3,2,1,0,1},
{4,3,2,1,0},
};
SymmtrixMatrixsm((int*)a,5);
sm.Print(5);
}
intmain()
{
Test();
system("pause");
return0;
}