1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > c语言对称矩阵的压缩存储_【数据结构】对称矩阵及对称矩阵的压缩存储

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

时间:2018-09-15 08:05:30

相关推荐

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

对称矩阵:

设一个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;

}

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。