稀疏矩阵的快速转置(C语言)算法详解

http://data.biancheng.net/view/188.html

稀疏矩阵的转置

需要经历以下 3 步:

  1. 将矩阵的行数和列数互换;
  2. 将三元组表(存储矩阵)中的 i 列和 j 列互换,实现矩阵的转置;
  3. 以 j 列为序,重新排列三元组表中存储各三元组的先后顺序;

稀疏矩阵快速转置算法和普通算法的区别仅在于第 3 步,快速转置能够做到遍历一次三元组表即可完成第 3 步的工作
稀疏矩阵的快速转置,在普通算法的基础上增设两个数组(假设分别为 array 和 copt):

  • array 数组负责记录原矩阵每一列非 0 元素的个数
  • copt 数组用于计算稀疏矩阵中每列第一个非 0 元素在新三元组表中存放的位置

copt数组
【1列首非0默认1】默认第一列首个非 0 元素存放到新三元组表中的位置为 1,
【前列位置+该列个数】然后后续各列首个非 0 元素存放到新三元组表的位置==前一列首个非 0 元素的存放位置加上该列非 0 元素的个数
通过 cpot[col] = cpot[col-1] + array[col-1] 公式可计算出后续各列首个非 0 元素存放到新三元组表的位置。

注意,cpot[col] = cpot[col-1] + array[col-1] 的意思是,后一列首个非 0 元素存放的位置等于前一列首个非 0 元素的存放位置加上该列非 0 元素的个数。由此可以看出,copt 数组才是最终想要的,而 array 数组的设立只是为了帮助我们得到 copt 数组。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是三元组存储稀疏矩阵快速转置C语言实现算法: ```c #include <stdio.h> #include <stdlib.h> #define MAXSIZE 1000 // 定义三元组最大元素个数 // 三元组结构体 typedef struct { int i, j, e; // 行下标、列下标、元素值 } Triple; // 稀疏矩阵结构体 typedef struct { Triple data[MAXSIZE + 1]; // 三元组表,data[0]未用 int mu, nu, tu; // 行数、列数、非零元素个数 } Matrix; // 稀疏矩阵转置 void Transpose(Matrix M, Matrix *T) { int p, q, col; int num[M.nu + 1]; int cpot[M.nu + 1]; T->mu = M.nu; T->nu = M.mu; T->tu = M.tu; if (T->tu) { for (col = 1; col <= M.nu; ++col) num[col] = 0; for (p = 1; p <= M.tu; ++p) ++num[M.data[p].j]; cpot[1] = 1; for (col = 2; col <= M.nu; ++col) cpot[col] = cpot[col - 1] + num[col - 1]; for (p = 1; p <= M.tu; ++p) { col = M.data[p].j; q = cpot[col]; T->data[q].i = M.data[p].j; T->data[q].j = M.data[p].i; T->data[q].e = M.data[p].e; ++cpot[col]; } } } int main() { Matrix M, T; int i, j, k; printf("请输入稀疏矩阵的行数、列数和非零元素个数:"); scanf("%d%d%d", &M.mu, &M.nu, &M.tu); printf("请输入稀疏矩阵的三元组表:\n"); for (k = 1; k <= M.tu; ++k) { scanf("%d%d%d", &M.data[k].i, &M.data[k].j, &M.data[k].e); } Transpose(M, &T); printf("转置后的稀疏矩阵的三元组表为:\n"); for (k = 1; k <= T.tu; ++k) { printf("%d %d %d\n", T.data[k].i, T.data[k].j, T.data[k].e); } return 0; } ``` 算法思路: - 遍历原稀疏矩阵中每个非零元素,统计每列非零元素个数并存储在num数组中。 - 根据num数组计算每列第一个非零元素在转置后的三元组表中的位置并存储在cpot数组中。 - 遍历原稀疏矩阵中每个非零元素,将其转置后存储在转置后的三元组表中。由于转置后的三元组表是按列存储的,因此要先按列顺序遍历,再按行顺序存储。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值