数组-稀疏矩阵的转置
第1关:一般转置算法
任务描述
本关任务:实现稀疏矩阵的转置操作(采用一般转置算法,即按列序转置)。
相关知识
为了完成本关任务,你需要理解:1. 矩阵的压缩存储,2.稀疏矩阵的三元组顺序表存储表示,3.一般转置算法。
矩阵的压缩存储
矩阵的压缩存储是指:为多个值相同的非零元素只分配一个存储空间,对零元素不分配空间,从而节省存储空间。
稀疏矩阵的三元组顺序表存储表示
稀疏矩阵是指非零元素的个数远远少于总的元素个数,且非零元素的分布没有规律。
稀疏矩阵的压缩存储就是只存储非零元素;且存储非零元素的值的同时,还需存储其所在的行和列。
于是,将非零元所在的行、列及其值构成一个三元组(i,j,v),且按行优先方式排列三元组,从而构成稀疏矩阵的三元组线性表,称为三元组表。
三元组表的存储方式有顺序存储和链式存储,从而可引出稀疏矩阵的两种压缩存储方式:三元组顺序表存储和十字链表存储。
本文介绍了稀疏矩阵的转置操作,包括一般转置算法和快速转置算法。首先讲解了矩阵的压缩存储、稀疏矩阵的三元组顺序表存储表示,接着详细阐述了一般转置算法的工作原理,并提供了编程要求。然后,文章引入了快速转置算法,通过预处理数组提高转置效率。每个部分都包含任务描述、相关知识和编程要求,帮助读者理解和实现稀疏矩阵的转置。
订阅专栏 解锁全文
1927

被折叠的 条评论
为什么被折叠?



