练习9——稀疏矩阵

本文详细介绍了如何对稀疏矩阵进行转置操作,包括两种不同的算法:一种是基本的转置方法,其时间代价为O(cols*terms),另一种是快速转置算法,具有较好的时间复杂度和空间效率,特别适合非零元素较少的情况。文中还提供了完整的代码实现。
摘要由CSDN通过智能技术生成

1、转置

1.1第一种想法

1.1.1思想:每次从原矩阵中复制一列到新的矩阵中。1)设矩阵列数为cols,对矩阵三元组扫描cols次;2)第k次扫描寻找所有列号为k的项:将其行号变列号、列号变行号,顺次存于转置矩阵三元组中。

1.1.2代码

void SparseMatrix::Transpose(SparseMatrix &b) {
    b.Rows=Rows;b.Cols=Cols;b.Terms=Terms;
    if(Terms==0)
        return ;
    int CurrentB=0;
    int i,k;
    for(k=0;k<Cols;k++){
        for(i=0;i<Terms;i++){
            if(smArray[i].col==k){
                b.smArray[CurrentB].row=k;
                b.smArray[CurrentB].col=smArray[i].row;
                b.smArray[CurrentB].value=smArray[i].value;
                CurrentB++;
            }
        }
    }
}

1.1.3评价:算法的时间代价为O(cols*terms)。如果非零元素变多时,算法的时间代价也会变大。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值