求教数据结构问题->稀疏矩阵的转置效率问题

qeizi 2004-01-15 11:53:14
请问一下大侠,对于稀疏矩阵中怎么样来提高转置时的效率问题呢。如下面常用写法:
template<class Type> SparseMatrix<Type> SparseMatrix<Type>::Transpose(){
SparseMatrix<Type> b(Cols,Rows);
b.Rows = Cols; //Rows和cols分别是稀疏矩阵的行数和列数
b.Cols = Rows;          
b.Terms = Terms;     //Terms是稀疏矩阵的非零元素个数,value为值
if ( Terms > 0 )
int CurrentB = 0;    //存放位置指针
for(int k = 0;k < Cols; k++ ) //在数组中查找列号为K的三元组
for(int i = 0;i < Terms; i++ )
if ( smArray[ i ].col == k ){ //第I个三元组中元素的列号为k
b.smArray[ CurrentB ].row = k;
b.smArray[ CurrentB ].col = smArray[ i ].row;
b.smArray[ CurrentB ].value = smArray[ i ].value;
CurrentB++;
}
}
return b;
}

若设稀疏矩阵的行数为Rows,列数为Cols,非零元素个数为Terms,则最坏情况下的时间复杂度主要取决于二重嵌套for循环内的if语句,if语句在二重循环的作用下总的执行次数为O(Cols X Terms)。而在if控制内的赋值语句则执行了Terms次,它取决于三元组表本身的长度。如果非零元素Terms与矩阵行、列数的乘积Rows X Cols等数量级,则程序的算法时间复杂度为O(Cols X Terms)=O(Rows X Cols的平方),设Rows = 500,cols=100,TERms=10000,则O(50 X 100的平方)=O(5 000 000),处理效率极低。
  
   因此请问大侠们的改进算法!!!!
...全文
153 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
qeizi 2004-01-16
  • 打赏
  • 举报
回复
是的,谢谢楼上的UP!!!我也是一时在写,就遇到了这么些问题。请大家多帮忙!!!
yjh1982 2004-01-15
  • 打赏
  • 举报
回复
空间换时间么.
纪俊 2004-01-15
  • 打赏
  • 举报
回复
学过
但是由于没有实践过不是很懂
帮你up下作为支持

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧