数据结构|对称矩阵压缩存储的下标公式推导|如何求对称矩阵压缩存储对应的一维数组下标

因为考试的时候可能会给很多情况的变式题,所以要会推导而不是背公式,情况变了,公式就不管用了。

行优先、只存储主对角线+下三角区:

矩阵下标 ai,j(i>=j)->一维数组下标 B[k]

按照行优先的原则,确定 ai,j 是一维数组中 B[k] 中的第几个元素

i 是行数,j 是列数

ai,j 在第 i 行,由上图可知,第 i 行有 i 个元素;ai,j 在第 j 列,也可以理解为在第 i 行的弟 j 个位置。

所以,a i,j** 元素的前面一共有的元素个数为: [1+2+...+(i-1)]+j**

即:

如果数组下标是从 0 开始的,a i,j** 元素的数组下标就是**

如果数组下标是从 1 开始的,a i,j** 元素的数组下标就是**

如果访问的是上三角的元素怎么办呢?也就是 i<j 的时候

由于对称矩阵的性质** ai,j=aj,i**
所以,如果存储的是上三角(i<j)的元素,可以转化成下三角的存储(i>j)

对于不包括主对角线的下三角,上三角的 ai,j 对应着下三角的aj,i

所以:

如果数组下标是从 0 开始的,a i,j** 元素的数组下标就是**

如果数组下标是从 1 开始的,a i,j** 元素的数组下标就是

相关推荐
林熙蕾LXL几秒前
进程处理操作
开发语言·c++·算法
代码无bug抓狂人几秒前
用回溯算法解决01背包
数据结构·算法
Shan12052 分钟前
二叉树的遍历算法之中序遍历
算法
Odedipus5 分钟前
二叉树的学习笔记
数据结构·笔记·学习
晨曦中的暮雨7 分钟前
动态规划专题Day1——打家劫舍系列
算法·动态规划
khalil10208 分钟前
代码随想录算法训练营Day-52 图论03 | 101.孤岛的总面积、102.沉没孤岛、103.水流问题、104.建造最大岛屿
c++·算法·图论
老四啊laosi8 分钟前
[滑动窗口] 13. 水果成篮
算法·leetcode·滑动窗口·水果成篮
刀法如飞12 分钟前
Palantir技术原理深度分析:Ontology 存储结构与读写方式
人工智能·算法·架构
澈20715 分钟前
图论基础:邻接矩阵与邻接表详解
算法·图论·邻接矩阵
白日做梦Q20 分钟前
Miniconda 新手保姆级教程:从安装到熟练使用(全程无跳步,避坑指南附全)
人工智能·深度学习·算法·机器学习