数据结构之数组矩阵存储

目录

一、数组存储

[1. 一维数组](#1. 一维数组)

[2. 二维数组](#2. 二维数组)

二、特殊矩阵存储

[1. 对称矩阵](#1. 对称矩阵)

[2. 三角矩阵](#2. 三角矩阵)

[3. 三对角矩阵](#3. 三对角矩阵)

三、总结


一、数组存储

1. 一维数组

2. 二维数组

二维数组按列优先存储的下标对应关系(A _m*_n)

二、特殊矩阵存储

1. 对称矩阵

上、下三角区的元素相同,存储元素,会浪费一半的空间,因此只需存放 (n + 1) * n / 2 个元素

2. 三角矩阵

  • 计算A[i, j]存放在一维数组的位置

技巧:直接令i, j = n 代入选项,检验是否与(n + 1) * n / 2相同,同样需要注意数组下标起始位置

3. 三对角矩阵

矩阵第一行和最后一行只有两个元素,其余行有3个元素;计算矩阵和数组下标对应关系时,按照特点算即可,一般都是计算具体元素的下标对应。计算可以从先算前(i - 1)行的元素数 + 相差元素个数(从左往右 ); 也可以直接算出第i行最后一个元素,然后减去相差元素个数(从右往左)。


三、总结

数组在编程中是十分常用的一种数据结构,以后遇到的许多算法都会有它的身影,比如KMP算法定义next数组、其随机存取的特点可以用来排序、动态规划等问题。上述内容如果有错误的地方,希望大佬们可以指正。我一直在学习的路上,您的帮助使我收获更大!觉得对您有帮助的话,还请点赞支持!我也会不断更新文章!

相关推荐
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎20 小时前
LIST 的相关知识
数据结构·list
M--Y21 小时前
Redis常用数据类型
数据结构·数据库·redis
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿21 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz1 天前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能1 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****1 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能1 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能1 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数