数据结构-上三角矩阵存储方式[0知识掌握]

目标:看完本文章你将会了解上三角矩阵的存储方式以及矩阵中数据的位置索引号如何求

难点:上三角矩阵的公式推导,上三角任意位置对应的存储位置。

一、准备知识

1.求和公式

前n项和:Sn = n(a1+an)/2

公差:d=后项-前项

项次:有多少个数需要求和,能表示出项次即可,矩阵中可能n表示项次,也可能n-1,或i-1只是形式不同而已。项次是比较核心,注意结合后续矩阵理解它的定位。

an项如何求:an=a1+(n-1)d, 这是求n项实际对应具体的数据,使用该公式即可。

2.内存存储地址如何编号

内存地址以1个字节为单位,1个字节8位,对应一个地址。比如int a = 8; 实际占用4个字节,即有4个地址,如果取a地址,&a取到的只是首地址,知道首地址,那么结束在什么地方,即根据int计算,int占用4个字节,如果首地址是2001,那么2001-2004位该整型的存储空,实际可使用的地址只是2001,其它三个地址被int屏蔽为不可见,如果非要去取2002能取到吗,直接用指针+1是无法获取到的。因为+1,实际到2005, 感兴趣的可以思考,如何去取2002,此处不讨论这个。

二、上三角矩阵

对角线上半部分是不同的数据,对角线下半部分数据相同所以用一个存储空间存储即可。

(一)数据存储:使用顺序存储,将该矩阵数据存储一维数组中,可以用静态分配或动态分配。

静态分配:比如矩阵中都是int, 声明数组int S[m]; 数组大小m=矩阵中的所有数据,

矩阵上半部分数据:n,n-1,n-2,n-3,.... 1, 使用求和公式 n(n+1)/2 得出总的数据量

矩阵下半部分:1个

总数的数据:m=n(n+1)/2+1, 上半部分数据量+下半部分数据量。m=11

动态分配:实际上一样,即int *S = (int *)malloc(m*sizeof(int)). m=11。

本例使用静态分配,分配完成后,这样即获得了内存的空间,以行序方式进行矩阵的存储。

分配后的对应关系如下

数据: a11 a12 a13 a14 a22 a23 a24 a33 a34 a44 C ....n

索引: 0 1 2 3 4 5 6 7 8 9 10....m

现在想知道a44的存储索引,如何计算。

1.要知道a44的位置,需要知道a44前面有多少数据,可以观察他们的关系是

n,n-1,n-2... a44, 比如a44是i行,那么去除a44本身求和即求n,n-1,n-2,......i-1的和,

注意为什么是i-1,i-1表示的是矩阵中项次对应的数据,实际可以理解成是只知道项次而不知道具体对应的数值,是需要求出来的,如果求出了i-1项次对应的实际数据,那么a44前n项和就很简单了,可根据公式am=a1+(m-1)d求值,通过观察公差d是-1,a1是n,m=i-1项次, 得出ai-1=n+(i-1-1)*-1=n-i+2;

所以i-1项次的数据就是n-i+2;a1=n,知道首项、末项、项次,直接带入求和公式

(i-1)(n+n-i+2)/2 =(i-1)(2n-i+2)/2,此时项次i-1=a44的前n项和或者说前面有多少元素就算出来了。后面在加上j-i+1,即可算出当前a44所在的位置。

存储位置或即下标索引k=(i-1)(2n-i+2)/2+j-i+1 = 10,因为数组下标是从0开始所以在-1实际是k=9

相关推荐
柴猫°1 天前
离散图扩散模型中的转移公式推导
人工智能·线性代数·机器学习
yeflx1 天前
本质矩阵、基础矩阵和单应矩阵详解
线性代数·矩阵
AI算法沐枫1 天前
计算机视觉需要哪些数学基础?常见问题全解析
人工智能·深度学习·线性代数·计算机视觉·自然语言处理
王_teacher2 天前
机器学习 矩阵求导 完整公式+严谨推导
人工智能·线性代数·考研·机器学习·矩阵·线性回归
做cv的小昊2 天前
【TJU】研究生应用统计学课程笔记(2)——第一章 数理统计的基本知识(1.3 统计中常用的分布族)
笔记·线性代数·数学建模·矩阵·概率论·学习方法·抽象代数
二等饼干~za8986682 天前
GEO 源码部署搭建详细操作教程(2026 最新版)
线性代数·django·开源·音视频·ai-native
Pentane.2 天前
【力扣hot100】【Leetcode 54】螺旋矩阵|边界控制 算法笔记及打卡(19/100)
算法·leetcode·矩阵
博.闻广见2 天前
AI_线性代数-6.PCA降维详解
人工智能·线性代数
做cv的小昊2 天前
【TJU】研究生应用统计学课程笔记(3)——第一章 数理统计的基本知识(1.4 正态总体的样本均值和样本方差的分布、1.5 充分统计量和完备统计量)
笔记·学习·线性代数·机器学习·数学建模·概率论
mxwin2 天前
Unity URP 下 TBN 矩阵学习 切线空间、tangent.w 与镜像 UV 的那些坑
学习·unity·矩阵·shader