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

【数据结构】:数组及特殊矩阵

数组及特殊矩阵

请添加图片描述

请添加图片描述

一、认识数组

1️⃣ 定义

  1. 什么是数组

    数组是由n(n⩾1)n(n\geqslant1)n(n1)相同类型的数据元素的有限序列

    除了定义还需认识一些知识点:

    • 💡数组元素:数组中的每个数据元素称为一个数组元素。
    • 💡元素下标:每个元素中的序号
    • 💡维界:下标的取值范围(例:下图0…6为该数组维界)
    • 💡维数:a[7]: 一维数组、a[2][2]:二维数组、a[1][2][3]:三维数组
    • 💡 各数组元素大小相同(数据类型相同,字长相同,即大小相同),且物理上连续存放
      在这里插入图片描述
  2. 👀数组与线性表的关系

    1. 数组是线性表的推广。一维数组可以视为一个线形表;二维数组可视为其元素也是定长线性表的线性表。
    2. 数组一旦被定义,其维数和维界就不在改变。因此,除结构的初始化和销毁外,数组只会有存取元素和修改元素的操作。

2️⃣ 存储结构

由于数组在物理上是连续存储的,所以只要知道数组的起始地址、数据类型,就可以算出其存储位置

1. 一维数组

若一维数组A[n],则其存储结构关系式为:

数组下标从0开始:LOC(A[i]) = LOC(A[0])+i*sizeof(ElemType)        (0<=i<n-1)数组下标从1开始:LOC(A[i]) = LOC(A[1])+(i-1)*sizeof(ElemType)    (1<=i<n)

🐂小试牛刀


📋题目描述:
  一维数组A[0...n]采用顺序存储结构,每个元素占用4个字节,该数组的首地址为120,求A[4]的存储地址( )

👻题目解析
注意数组下标是从0开始的
  如图:在这里插入图片描述
  💡第一个4:0 – 4之间一共有四个元素
  💡第二个4:该数组是int类型,字节为4B

✅正确答案:136

2. 二维数组

对于多维数组,有两种映射方法:按行优先、按列优先

  1. 按行存储

    📌基本思想先行后列,先存储行号比较小的元素,行号相等先存储列号比较小的元素。

    设二维数组A[m][n],则存储结构关系式为:

    数组下标从0开始:LOC(A[i,j]) = LOC(A[0,0])+(i*n+j)*sizeof(ElemType) 数组下标从1开始:LOC(A[i,j]) = LOC(A[1,1])+[(i-1)*n+j]*sizeof(ElemType) 
    

    🐂小试牛刀


    📋题目描述:
      假设二维数组A[3,4]每个元素占用2个存储单元,数组元素(A[0][0])的起始地址为1000,求数组元素A[2][2]的起始地址。

    👻题目解析
    注意数组下标是从0开始的
      公式求解:LOC(A[2,2]) = LOC(A[0,0])+(2*4+2)*2=1000+20=1020
      图解:在这里插入图片描述

    ✅正确答案:1020

    • 列优先(原理同上)

      📌基本思想先列后行,先存储列号比较小的元素,列号相等先存储行号比较小的元素。

      设二维数组A[m][n],则存储结构关系式为:

      数组下标从0开始:LOC(A[i,j]) = LOC(A[0,0])+(j*n+i)*sizeof(ElemType) 数组下标从1开始:LOC(A[i,j]) = LOC(A[1,1])+[(j-1)*n+i]*sizeof(ElemType) 
      

请添加图片描述

二、特殊矩阵的压缩存储

1.💡 压缩矩阵:指为多个值相同的元素分配一个存储空间,对零元素不分配存储空间。其目的是节省存储空间
2. 💡特殊矩阵:值具有许多相同矩阵元素或零元素,并且这些相同矩阵元素或零元素的分布有一定规律性的矩阵。常见特殊矩阵有对称矩阵、上(下)三角矩阵、对角矩阵等。
3. 💡特殊矩阵的压缩存储方法:找到特殊矩阵中值相同的矩阵元素的分布规律,把那些呈现规律性分布的、值相同的多个矩阵元素压缩到一个存储空间中。

1️⃣ 对称矩阵

  1. 对称矩阵是什么❓
    上三角区的元素==下三角区元素,A[i][j]==A[j][i]
    在这里插入图片描述

  2. 对称矩阵为何不能用二维矩阵存储❓
    对于n阶对称矩阵,上三角元素的所有元素和下三角区对应的元素相同,若扔采用二维数组存放,则会浪费一半的空间,对此将对称矩阵存放在一维数组中。

  3. 那么如何将二维数组存储于一维数组❓

    💤思考1:有多少个二维元素A[0...n-1][0...n-1]存于一维元素中❓


    由于上三角区==下三角区,只需要在一维数组中存储主对角线+下三角区
    在这里插入图片描述

    1(A[0])1  个元素
    第 2(A[1])2  个元素
    第 3(A[2])3  个元素
    ......
    第 n 行(A[n-1]):n个元素(❗由于数组从0开始,A[0]占了一行,所以A[n]是第n-1行)共:1+2+3+...+n=[1+n]*n/2=(n+1)*n/2
    

    答案:一维数组共需存储(n+1)∗n2\frac {(n+1)*n} 22(n+1)n个元素

    💤思考2:按行排列,二维数组A[0…n-1][0…n-1]与一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n} 2-12(n+1)n1]对应的关系❓

    在这里插入图片描述
    👀看图做题:

    1. A[1][1]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n } 2-12(n+1)n1]的位置:
      A[1][1]位于第2行的第2列第1行:共1个元素第2行:有2个元素
      求和:1+2=3
      B的下标从0开始,所以3-1=2,即A[1][1]`在一维数组B[2]
    2. A[2][1]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n} 2-12(n+1)n1]的位置:
      A[2][1]位于第3行的第2列第1行:共1个元素第2行:共2个元素第3行:有2个元素
      求和:1+2+3=5
      B的下标从0开始,所以5-1=4,即A[2][1]在一维数组B[4]
    3. A[i][j]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n } 2-12(n+1)n1]的位置:
      A[i][j]位于第i+1行的第j+1列第 1 行:共 1 个元素第 2 行:共 2 个元素第 3 行:共 3 个元素...第 i 行:共 i 个元素第i+1行:有j+1个元素
      求和:1+2+3+...+i+(j+1)=(i+1)*i/2+(j+1)
      B的下标从0开始,所以(i+1)*i/2+(j+1)-1=(i+1)*i/2+j,即A[i][j]`在一维数组B[(i+1)*i/2+j]

    答案:按行排序,二位数组A[i][j]与一维数组B[(i+1)∗i2+j\frac {(i+1)*i} 2+j2(i+1)i+j]对应

    💤思考3:按列排列,二维数组A[0…n-1][0…n-1]与一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n } 2-12(n+1)n1]对应的关系❓


    在这里插入图片描述
    👀看图做题:

    1. A[1][1]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n } 2-12(n+1)n1]的位置:
      A[1][1]位于第2行的第2列第1列:共n-1个元素第2列:有1个元素
      求和:n-1+1=n
      B的下标从0开始,所以n-1=(n-1),即A[1][1]`在一维数组B[n-1]
    2. A[2][1]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n} 2-12(n+1)n1]的位置:
      A[2][1]位于第3行的第2列第1列:共n-1个元素第2列:共2个元素
      求和:n-1+2=n+1
      B的下标从0开始,所以n+1-1=n,即A[2][1]`在一维数组B[n]
    3. A[i][j]在一维数组B[0… (n+1)∗n2−1\frac {(n+1)*n } 2-12(n+1)n1]的位置:
      A[i][j]位于第i+1行的第j+1列第 1 列:共 n-1 个元素第 2 列:共 n-2 个元素第 3 列:共 n-3 个元素...第 j 列:共 n-j 个元素第j+1列:有i+1-j个元素
      求和:(n-1)+(n-2)+(n-3)+...+(n-j)+(i+1-j)=(n-1+n-j)*j/2+i+1-j=(2n-1-j)*j/2+i+1-j
      B的下标从0开始,所以(2n-1-j)*j/2+i+1-j-1=(2n-1-j)*j/2+i-j,即A[i][j]在一维数组B[(2n-1-j)*j/2+i-j]

    答案:按列排序,二位数组A[i][j]与一维数组B[((2n−1−j)∗j2+i−j\frac {((2n-1-j)*j} 2+i-j2((2n1j)j+ij]对应

    💤思考4:思考二、三都是以下三角区为例,那么上三角区如何存储❓

    在这里插入图片描述
    由图可知,上三角区与下三角区的关系为:A[i][j]==A[j][i]
    所以:

    • 💡上按行==下按列,二位数组A[i][j]与一维数组B[((2n−1−i)∗i2+j−i\frac {((2n-1-i)*i} 2+j-i2((2n1i)i+ji]对应
    • 💡上按列==上按排,二位数组A[i][j]与一维数组B[(j+1)∗j2+i\frac {(j+1)*j} 2+i2(j+1)j+i]对应

2️⃣ 三角矩阵

  1. 三角矩阵是什么❓
    三角矩阵可以分为上三角矩阵和下三角矩阵

    • 💡下三角矩阵:上三角区所有元素均为一个常量
    • 💡上三角矩阵:下三角区所有元素均为一个常量
      在这里插入图片描述
  2. 三角矩阵如何存储❓

    💤思考5:有多少个二维元素A[0...n-1][0...n-1]存于一维元素中❓

    以下三角矩阵为例:

      三角矩阵与对称矩阵的存储方式相似,不同之处在于,)存储完下三角区和主对角线后,紧接着存储上三角区的常量一次
    在这里插入图片描述

    由对称矩阵可知,下三角区+主对角线的元素=(n+1)*n /2个元素
    三角矩阵多了一个常量:所以共有(n+1)*n /2+1个元素
    

    答案:一维数组共需存储(n+1)∗n2+1\frac {(n+1)*n} 2+12(n+1)n+1个元素

    💤思考6:下三角矩阵如何存储❓

    1. 按行存储
      在这里插入图片描述
      👀看图知:

      • 💡三角矩阵的下三角区+主对角线与对阵矩阵存储相同,可直接使用思考二的结论.
      • 💡三角矩阵的上三角区的常量存于一维数组的最后,所以位置固定:(n+1)∗n2\frac {(n+1)*n} 22(n+1)n

      答案:按行排序,二维数组A[i][j]B[k]相对应,其中k={(i+1)∗i2+j(下和主元素)(n+1)∗n2+1(上元素)k= \begin{cases} {\frac {(i+1)*i} 2+j} (下和主元素) \\ \\ \frac {(n+1)*n} 2+1(上元素) \end{cases}k=2(i+1)i+j(下和主元素)2(n+1)n+1(上元素)

    2. 按列存储
      在这里插入图片描述
      👀看图知:

      • 💡三角矩阵的下三角区+主对角线与对阵矩阵存储相同,可直接使用思考三的结论.
      • 💡三角矩阵的上三角区的常量存于一维数组的最后,所以位置固定:(n+1)∗n2\frac {(n+1)*n} 22(n+1)n

      答案:按行排序,二维数组A[i][j]B[k]相对应,其中k={((2n−1−j)∗j2+i−j(下和主元素)(n+1)∗n2+1(上元素)k= \begin{cases} {\frac {((2n-1-j)*j} 2+i-j} (下和主元素) \\ \\ \frac {(n+1)*n} 2+1(上元素) \end{cases}k=2((2n1j)j+ij(下和主元素)2(n+1)n+1(上元素)

    💤思考7:上三角矩阵如何存储❓

    1. 按行存储
      在这里插入图片描述
      👀图知:

      • 💡三角矩阵的上三角区+主对角线与对阵矩阵存储相同,可直接使用思考四的结论.
      • 💡三角矩阵的下三角区的常量存于一维数组的最后,所以位置固定:(n+1)∗n2\frac {(n+1)*n} 22(n+1)n

      答案:按行排序,二维数组A[i][j]B[k]相对应,其中k={((2n−1−i)∗i2+j−i(上和主元素)(n+1)∗n2+1(下元素)k= \begin{cases} {\frac {((2n-1-i)*i} 2+j-i} (上和主元素) \\ \\ \frac {(n+1)*n} 2+1(下元素) \end{cases}k=2((2n1i)i+ji(上和主元素)2(n+1)n+1(下元素)

    2. 按列存储
      👀知:

      • 💡三角矩阵的上三角区+主对角线与对阵矩阵存储相同,可直接使用思考四的结论.
      • 💡三角矩阵的下三角区的常量存于一维数组的最后,所以位置固定:(n+1)∗n2\frac {(n+1)*n} 22(n+1)n

      答案:按行排序,二维数组A[i][j]B[k]相对应,其中k={(j+1)∗j2+i(上和主元素)(n+1)∗n2+1(下元素)k= \begin{cases} {\frac {(j+1)*j} 2+i} (上和主元素) \\ \\ \frac {(n+1)*n} 2+1(下元素) \end{cases}k=2(j+1)j+i(上和主元素)2(n+1)n+1(下元素)

3️⃣三对角矩阵

  1. 三对角矩阵是什么❓

    • 💡三对角矩阵又称带状矩阵
    • 💡对于n阶方阵A中的任一元素aija_ijaij,当∣i−j∣>1|i-j|>1ij>1时,有aij=0(0⩽i,j⩽n−1)a_ij=0(0\leqslant i,j\leqslant n-1)aij=0(0i,jn1)
      在这里插入图片描述
  2. 三对角矩阵如何存储❓

    💤思考8:有多少个二维元素A[0...n-1][0...n-1]存于一维元素中❓

      由上图可知,除了第一行和最后一行为两个元素,其他每行都为三个元素,共有3*n-2个元素

    答案:一维数组共需存储3∗n−23*n-23n2个元素

    💤思考9:按行排序,二维数组A[0...n-1][0...n-1]与一维数组B[0...3n-3]对应的关系❓

      
    A[i][j]在一维数组B[0...3n-3]的位置:

    A[i][j]位于第i+1行的第j+1列第 1 行:共 2 个元素第 2 行:共 3 个元素第 3 行:共 3 个元素...第 i 行:共 3 个元素第i+1行:有j-i+2个元素
    求和:2+3+3+...+3+j-i+2=(3i-1)+j-i+2=2i+j+1
    B的下标从0开始,所以2i+j+1-1=2i+j,即A[i][j]在一维数组B[2i+j]

    答案:按行排序,二位数组A[i][j]与一维数组B[2i+j]对应

    💤思考10:按列排序,二维数组A[0...n-1][0...n-1]与一维数组B[0...3n-3]对应的关系❓

      
    A[i][j]在一维数组B[0...3n-3]的位置:

    A[i][j]位于第i+1行的第j+1列第 1 列:共 2 个元素第 2 列:共 3 个元素第 3 列:共 3 个元素...第 j 列:共 3 个元素第j+1列:有i-j+2个元素
    求和:2+3+3+...+3+i-j+2=(3j-1)+i-j+2=2j+i+1
    B的下标从0开始,所以2j+i+1-1=2j+i,即A[i][j]在一维数组B[2j+i]

    答案:按列排序,二位数组A[i][j]与一维数组B[2j+i]对应

请添加图片描述

三、稀疏矩阵

  1. 什么样的矩阵是稀疏矩阵❓
    💡非零元素远远少于矩阵元素个数
    例:100*100矩阵中,只有100个非零元素。
  2. 存储方式有哪些❓
    1. 三元组
      在这里插入图片描述

    2. 十字链表法
      在这里插入图片描述

参考资料

《王道:23数据结构考研复习指导》

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

相关文章:

  • 记录一下微信小程序里使用SSE
  • API 接口安全:用 JWT + Refresh Token 解决 Token 过期与身份伪造问题
  • 云手机搬砖 高效采集资源
  • GitHub Actions CI/CD 自动化部署完全指南
  • Fastlane 结合 开心上架 命令行版本实现跨平台上传发布 iOS App
  • 广东营销网站建设服务公司军事信息化建设网站
  • Go Web 编程快速入门 14 - 性能优化与最佳实践:Go应用性能分析、内存管理、并发编程最佳实践
  • LeetCode每日一题——合并两个有序链表
  • 丽江市建设局官方网站门户网站开发需要多少钱
  • 边缘计算中评估多模态分类任务的延迟
  • 11.9.16.Filter(过滤器)
  • 光储充微电网能量管理系统:构建绿色、高效、安全的能源未来
  • MR30分布式IO在自动上料机的应用
  • 有些网站为什么可以做资讯建站工具交流
  • .NET周刊【10月第2期 2025-10-12】
  • 自动化文献引用和交叉引用高亮显示:Word VBA宏解决方案
  • 大数据离线处理:使用 Airflow 调度 Hive 脚本的工作流设计
  • 深入理解二叉搜索树:从原理到实现
  • Rust 泛型参数的实践与思考
  • AppML 案例:Employees 应用解析
  • 【Qt开发】布局管理器(一)-> QVBoxLayout垂直布局
  • CF练习记录~
  • 自动化测试 | 认识接口自动化封装中的YAML用例
  • dedecms做门户网站石家庄网站建站
  • windows系统下docker desktop创建容器指定ip
  • 微网站建设费用预算旅游网站开发的需求
  • Ionic + Angular 跨端实战:用 Capacitor 实现相机拍照功能并适配移动端
  • Python 爬虫:从基础到实战的完整指南
  • Angular【http服务端交互】
  • Angular【核心特性】