当前位置: 首页 > news >正文

NO.4数据结构数组和矩阵|一维数组|二维数组|对称矩阵|三角矩阵|三对角矩阵|稀疏矩阵

![[Pasted image 20250712141812.png]]

数组的储存

【定义】

数组: 由 n(≥1) 个相同类型的数据元素构成的有限序列, 是线性表的推广。
一旦被定义, 维数和长度就不可再改变, 一般对其只有元素的存取和修改操作。

一维数组

Arr[a0,…,an−1] Arr[a_{0},\dots,a_{n-1}] Arr[a0,,an1]
计算 ai 的位置: pos(ai) = pos(a0) + i *L (ai 前面有 i 个元素)

二维数组

——可看作元素是一维数组的一维数组。 假设为 n*m 大小。
行优先
![[Pasted image 20250712143114.png]]

列优先
![[Pasted image 20250712143127.png]]

特殊矩阵的压缩

——多个值相同的元素只分配一个存储空间, 对零元素不分配空间。

对称矩阵

aij = aji
![[Pasted image 20250712143241.png]]

若从 a1,1 开始, 则 ai,j 在一维数组中存储下标

一般存储下三角矩阵
下三角区域(含主对角线)
第一行:1个元素
第二行:2个元素
第i-1行:i-1个元素
第i行:j-1个元素
故 aij 为第i(i-1)/2+j个元素

i(i-1)/2+j-1, i >= j 下三角区和主对角线
j(j-1)/2+i-1, i < j 上三角区

三角矩阵

——上三角区 or 下三角区全为同一常量 => 会浪费一半的存储空间。
![[Pasted image 20250712162901.png]]

![[Pasted image 20250712162909.png]]

下三角矩阵元素 aij 和数组下标的关系
n(n+1)/2, i < j 上三角区
i(i-1)/2+j-1, i ≥ j 下三角区和主对角线
![[Pasted image 20250713031706.png]]

上三角矩阵元素 aij 和数组下标的关系

上三角区域 (包含主对角线)
第一行:n个元素
第二行:n-1个元素
第i-1行:n-i+2个元素
第i行:j-i个元素
ai;为第(n+n-i+2)(i-1)/2 + j-i+1=(i-1)(2n-i+2)/2+j-i+1个元素

n(n+1)/2, i > j 下三角区
(i-1)(2n-i+2)/2 + (j-i), i ≤ j 上三角区和主对角线

三对角矩阵

——也称带状矩阵, 对于 ai,j,当|i-j|>1 时, 有 ai,j = 0
![[Pasted image 20250713032036.png]]

除第1行和第i行外,每行都有三个元素,
第i行有j-i+2个元素,
故aij为第(i-2)*3+2+j-i+2=2i+j-2个元素

三对角矩阵的顺序存储
![[Pasted image 20250713032112.png]]

三对角矩阵元素 aij 和数组下标的关系
k = 2i + j -3

稀疏矩阵储存方式

顺序储存(三元组表示法&伪地址表示法)
链式存储(邻接表表示法&十字链表表示法)
![[Pasted image 20250713032510.png]]

http://www.dtcms.com/a/277014.html

相关文章:

  • 电源中的声学-噪声,如何抑制开关电源的噪声
  • 飞算JavaAI:开启 Java 开发 “人机协作” 新纪元
  • 二叉树算法详解和C++代码示例
  • 项目合作复盘:如何把项目经验转化为可复用资产
  • 【C++】第十五节—一文详解 | 继承
  • ArkUI Inspector工具用法全解析
  • 【保姆级图文详解】Spring AI 中的工具调用原理解析,工具开发:文件操作、联网搜索、网页抓取、资源下载、PDF生成、工具集中注册
  • 在 JetBrains 系列 IDE(如 IntelliJ IDEA、PyCharm 等)中如何新建一个 PlantUML 文件
  • jEasyUI 创建带复选框的树形菜单
  • NLP-迁移学习
  • 【PyMuPDF】PDF图片处理过程内存优化分析
  • RHCIA第二次综合实验:OSPF
  • 电阻抗成像肺功能测试数据分析与直方图生成
  • 攻防世界——Web题 very_easy_sql
  • Rust 模块系统:控制作用域与私有性
  • python 虚拟环境 Anaconda Miniconda
  • 大模型的Temperature、Top-P、Top-K、Greedy Search、Beem Search
  • jeepay开源项目开发中金支付如何像其他支付渠道对接那样简单集成,集成服务商模式,极简集成工具。
  • AI驱动的软件工程(中):文档驱动的编码与执行
  • 深入解析 ArrayList
  • XGBoost三部曲:XGBoost原理
  • Docker一键安装中间件(RocketMq、Nginx、MySql、Minio、Jenkins、Redis)脚步
  • Transformer 小记(一):深入理解 Transformer 中的位置关系
  • 【PTA数据结构 | C语言版】字符串截取子串操作
  • ABP VNext + 多级缓存架构:本地 + Redis + CDN
  • ref 和 reactive
  • EWSGAN:自动搜索高性能的GAN生成器架构
  • LeetCode 1156.单字符重复子串的最大长度
  • 维基艺术图片: 数据标注 (2)
  • C语言基础教程(002):变量介绍