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

数据结构之数组矩阵存储

目录

一、数组存储

1. 一维数组

2. 二维数组

 二、特殊矩阵存储

1. 对称矩阵

2. 三角矩阵 

 3. 三对角矩阵

三、总结 


一、数组存储

1. 一维数组

2. 二维数组

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

LOC(a_i,_j) = LOC(a_0,_0) + (j * n + i) * data 

 二、特殊矩阵存储

1. 对称矩阵

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

2. 三角矩阵 

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

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

 3. 三对角矩阵

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


三、总结 

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


http://www.kler.cn/a/302034.html

相关文章:

  • 基于OpenCV的图片人脸检测研究
  • 同比缩放,64的倍数,最大值
  • ADC输出码和输入电压转换关系
  • 谷歌Gemini发布iOS版App,live语音聊天免费用!
  • postgresql.conf与postgresql.auto.conf区别
  • Android音视频直播低延迟探究之:WLAN低延迟模式
  • 树莓派安装 OpenCV 教程
  • 110个oracle常用函数总结
  • uniapp中基于vue3实现输入验证码功能
  • Android 地图搜索商家,检索关键字(高德地图,百度地图),地址搜索(1)
  • windows 显示进程地址空间
  • win11下面的virtualenv的使用(没写完)
  • Excel文档的读取(3)
  • 93、k8s之hpa+helm
  • AI prompt(提示词)
  • 根据ArrayList<Object>中对象的多个属性值进行模糊匹配,并找到所有匹配的对象
  • 企业应该如何安全上网,软件防查盗版,企业防盗版
  • uniapp如何监听页面滚动?
  • Boost.pyhon 使用方法
  • 图片详解,最简单易懂!!!Ubuntu增强功能
  • 轮询解决方案
  • C++20 新特征:概念(Concepts)全面解析
  • PointNet++改进策略 :模块改进 | SPVConv, 体素和点云特征融合提升小目标检测能力
  • html+css+js网页设计 旅游 龙门石窟4个页面
  • Spring Boot 注解探秘:Bean 管理的艺术
  • 【Qt应用】Qt编写简易登录注册界面