数据结构之数组矩阵存储

目录

一、数组存储

[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数组、其随机存取的特点可以用来排序、动态规划等问题。上述内容如果有错误的地方,希望大佬们可以指正。我一直在学习的路上,您的帮助使我收获更大!觉得对您有帮助的话,还请点赞支持!我也会不断更新文章!

相关推荐
坚持编程的菜鸟3 小时前
LeetCode每日一题——困于环中的机器人
c语言·算法·leetcode·机器人
Aurorar0rua4 小时前
C Primer Plus Notes 09
java·c语言·算法
我不是QI7 小时前
DES 加密算法:核心组件、加解密流程与安全特性
经验分享·算法·安全·网络安全·密码学
前端小刘哥7 小时前
新版视频直播点播EasyDSS平台,让跨团队沟通高效又顺畅
算法
明月(Alioo)8 小时前
机器学习入门,无监督学习之K-Means聚类算法完全指南:面向Java开发者的Python实现详解
python·算法·机器学习
叶梅树8 小时前
从零构建A股量化交易工具:基于Qlib的全栈系统指南
前端·后端·算法
lingran__8 小时前
算法沉淀第三天(统计二进制中1的个数 两个整数二进制位不同个数)
c++·算法
MicroTech20259 小时前
微算法科技MLGO推出隐私感知联合DNN模型部署和分区优化技术,开启协作边缘推理新时代
科技·算法·dnn
小冯记录编程9 小时前
深入解析C++ for循环原理
开发语言·c++·算法
hazy1k10 小时前
51单片机基础-矩阵按键
嵌入式硬件·矩阵·51单片机