【数据结构】矩阵的压缩存储

矩阵的压缩存储

5.1 普通矩阵的存储

  • 用二维数组存储

    分为行优先和列优先:

    行优先:优先存放一行的数据。

    列优先:优先存放一列的数据。

    • 注意下标是从0还是1开始的!

5.2 对称矩阵的存储

  • 对称矩阵定义

    若n阶方阵中任意一个元素 a i , j a_{i,j} ai,j都有 a i , j = a j , i a_{i,j}=a_{j,i} ai,j=aj,i。

  • 压缩存储策略

    只存储上或下三角区和主对角线。

  • 例:按行优先 将各元素存入一维数组

    • 数组大小应为多大?

      1 + 2 + 3 + 4... + n = ( 1 + n ) ∗ n / 2 1+2+3+4...+n=(1+n)*n/2 1+2+3+4...+n=(1+n)∗n/2

    • 如何把矩阵下标转化为一维数组下标?

    • 因为矩阵对称,所以可以将上三角区域元素的i和j互换,就变成和下三角区域一样了

    i ( i − 1 ) / 2 i(i-1)/2 i(i−1)/2是第i行前1~i-1行的所有元素数量;

    j − 1 j-1 j−1是 a i , j a_{i,j} ai,j元素在第i行的前的元素数量。如图:

5.3 三角矩阵的压缩存储

  • 三角矩阵

    上三角区域或者下三角区域为一常量。

  • 存储方法

    非常量区域和对称矩阵存储方法一毛一样。

    在数组最后存储常量的值。

5.4 三对角矩阵的压缩存储

  • 三对角矩阵的定义

    当 ∣ i − j ∣ > 1 |i-j|>1 ∣i−j∣>1,有 a i , j = 0 a_{i,j}=0 ai,j=0。

  • 存储方式

    只要存储值不为0的元素就好。

    • 如何将数组下标k转换为矩阵下标i,j?

5.5 稀疏矩阵的压缩存储

  • 稀疏矩阵定义

    非零元素远少于矩阵元素个数。

  • 存储方式

    1.顺序存储

    ​ 会失去随机存储的特性。

    2.链式存储------十字链表法

相关推荐
柒.梧.6 小时前
吃透HTTP及相关协议核心区别,从基础到进阶全覆盖
网络·网络协议·http
努力中的编程者7 小时前
栈和队列(C语言底层实现环形队列)
c语言·开发语言
forAllforMe7 小时前
用STM32+LAN9252, 生成一个etherCAT 从机系统,实现数据采集功能
网络·stm32·嵌入式硬件
程序员小寒7 小时前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·网络·性能优化
一叶落4387 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
y = xⁿ8 小时前
【LeetCodehot100】2:两数相加 19 删除链表倒数第n个节点
数据结构·链表
码不停蹄Zzz8 小时前
C语言——神奇的static
java·c语言·开发语言
wal13145208 小时前
OpenClaw教程(九)—— 彻底告别!OpenClaw 卸载不残留指南
前端·网络·人工智能·chrome·安全·openclaw
白藏y9 小时前
【协议】SSE协议和WebSocket协议
网络·websocket·网络协议
罗湖老棍子9 小时前
【例 1】数列操作(信息学奥赛一本通- P1535)
数据结构·算法·树状数组·单点修改 区间查询