Day36-【13003】短文,数组的行主序方式,矩阵的压缩存储,对称、三角、稀疏矩阵和三元组线性表,广义表求长度、深度、表头、表尾等

文章目录

  • 本次课程内容
  • 第四章 数组、广义表和串
    • 第一节 数组及广义表
      • 数组的基本操作
      • 数组的顺序存储方式-借用矩阵行列式概念
        • 二维数组C语言对应的函数-通常行主序方式
      • 矩阵的压缩存储
        • 对称矩阵和三角矩阵
        • 压缩存储后,采用不同的映射函数
        • 稀疏矩阵-可以构成三元组线性表
          • 三元组在C语言中的实现
          • 三元组表的转置
            • 三元组转置的算法实现
      • 数组的应用-解决迷宫问题
      • 广义表
        • 广义表示例
        • 广义表操作示例

本次课程内容

在这里插入图片描述

第四章 数组、广义表和串

在这里插入图片描述

第一节 数组及广义表

在这里插入图片描述

数组的基本操作

数组是高级程序设计语言中的重要语法成分,很多语言都定义了数组类型。例如,在C语言中,定义了一维数组。数组元素还可以是数组,由此得到数组的数组,

即多维数组。

一般将n(n>2)维数组看作n-1维数组的数组。

从数据结构的角度来理解,一维数组可以作为线性表的存储结构,数组中保存的各元素可以组成一个线性表。多维数组在系统内部都对应一个隐含的一维数组,所

以多维数组也是一种线性表。例如,二维数组就是以一维数组为元素的线性表。

数组的每个元素都是形如(index,value)的二元对,index是数组下标,也称为索引,value是对应于该下标的数值。任何两个元素的index值都不相同。

从数组的操作可知,它没有一般线性表常用的插入和删除操作,更多的是根据下标index访问元素。

数组的顺序存储方式-借用矩阵行列式概念

一维数组天然地采用顺序存储方式,

多维数组的顺序存储又是什么样的呢?

数组的顺序存储有两种形式。以二维数组为例,它的元素可以按行排列,也可以按列排列。

这里的“行”和“列”借用数学上矩阵或行列式中的概念。

所谓按行排列,就是先排数组的第一行,紧随其后排第二行,依此类推。

所谓按列排列,就是先排数组的第一列,紧随其后排第二列,依此类推。

最终都是将数组中的全部元素排列成一个序列。

在C语言中,可以定义多维数组,它的下标采取如下的形式表示:

在这里插入图片描述

二维数组C语言对应的函数-通常行主序方式

在这里插入图片描述

通常int类型占4字节,数组D2Array中含有18个元素,共占用18x4=72字节。如果保存的起始地址是1000,则数组将占用从1000到1071的内存空间。注意,这里

提到的字节编号并不是内存中真实的编号。将图4-1所示的下标表格按行自上而下、同一行中自左至右的次序进行连续编号,从0开始,

即可得到图4-2a所示的编号结果,

这种按行优先把二维数组中的下标映射到0~n-1之间的某个整数的方式称为按行优先方式,也称为行主序方式

包括C语言在内的大多数程序设计语言均采用行主序的实现模式。

也有一些程序设计语言采用另一种实现模式,称为按列优先方式,也称为列主序方式。

在列主序方式中,按列优先,对于下标表格,从第一列开始,从上到下进行连续编号,直到最后一列。这个结果如图4-2b所示。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

矩阵的压缩存储

数学中的矩阵可以使用二维数组保存。对于n行m列的矩阵,数组元素至少需要分配n x m个。

有些矩阵因其特殊性,可以不必保存其中的所有元素,因而可以减少为数组分配的空间

对称矩阵和三角矩阵

在这里插入图片描述
在这里插入图片描述

如果不考虑矩阵的特殊性,按照一般二维数组的顺序存储方式来存储特殊矩阵,也是完全可行的。

但是,从节省存储空间的角度考虑,对称矩阵和上(下)三角矩阵都可以只保存矩阵中约一半的元素,从而可以节省差不多一半的存储空间。

这样的存储形式称为压缩存储。

  • 具体来说,对干对称矩阵,因为对角线以上及以下的元素对称相等,所以只需要保存其中的一半及对角线上的元素

  • 对于上三角矩阵或下三角矩阵,仅保存上三角部分或下三角部分的元素,另外一半的0元素不再保存。

若矩阵有n行n列,则这三种形式下需要保存的元素个数为nx(n+1)/2。

在采用压缩存储以后,需要寻找与普通二维数组不同的映射函数。

压缩存储后,采用不同的映射函数

在这里插入图片描述

在这里插入图片描述

稀疏矩阵-可以构成三元组线性表

在实际的应用中,矩阵中可能会出现大量的0元素,而非0元素数量很少,这就是所谓的稀疏矩阵。至于非0元素少到什么程度才能称为稀疏矩阵,并没有很严格的定义。通常认为,矩阵中非0元素的个数与矩阵的阶数相当,即可将其看作稀疏矩阵

  • 如何理解?

为了节省空间,一般只存储稀疏矩阵中的非0元素。但在稀疏矩阵中,非0元素的出现是没有规律的,

所以在存储非0元素时必须将它所在的行号和列号一起存储起来。这些信息组成一个三元组(i,j,v)的形式

其中v表示非0元素的值,i表示v所在的行号,i表示v所在的列号。

一个稀疏矩阵的所有元素用一个三元组表来表示,也就是可以构成一个三元组的线性表

在这里插入图片描述

为了方便后续其他操作的实现,三元组表应该是一个有序序列,通常按行主序的次序排列,即先按行的大小排列,同一行的三元组再按列的大小排列。

三元组表的初始值从键盘输入,输入时,各三元组可以按行主序排列,也可以按任意的次序排列,但最终都应该按行主序的次序插入到一维数组的合适位置。

当然,在有特殊需求的应用中,也可以按列主序方式保存。

三元组在C语言中的实现

在这里插入图片描述

在这里插入图片描述

三元组表的转置

转置是矩阵中常用的一种操作。下面实现采用三元组表表示的稀疏矩阵的转置算法。矩阵转置即行、列互换,i行的元素放置到i列,这也意味着,j列的元素放置在j行。如果矩阵是nxm则转置后得到的矩阵是mxn的。
很容易想到,将三元组表中的每个三元组项的i与i互换,即可得到转置后矩阵的三元组表。但是,这样转换后得到的三元组表不再按行主序排列,不便于后续操作的实现。所以,要实现矩阵转置程序,必须先得到一个按行主序排列的三元组表。

可以像readSparseMatrix函数那样处理,读入原矩阵的一个三元组,插入到目标矩阵的三元组表中。在插入过程中,需要调整部分三元组在三元组表中的次序,也就是需要进行元素的移动。从顺序表实现的时间复杂度分析中知道,这样的移动会导致转置操作的效率很低。
可以使用一个临时计数数组,记录原矩阵的每个三元组在目标矩阵的三元组表中的插入位置,以辅助完成转置操作,由此避免了三元组的移动,可高效率地实现转置操作。
不失一般性,设原矩阵A的行数是rows,列数是cols,则转置后矩阵B的行数是cols,列数是rows。元组的个数没有改变。

在这里插入图片描述

三元组转置的算法实现

在这里插入图片描述

数组的应用-解决迷宫问题

多维数组,特别是二维数组,在计算机科学中有广泛的应用。

下面以一个有趣的“迷宫”问题为例,介绍数组的应用。

“老鼠走迷宫”是实验心理学中的一个经典问题,也是一种智力游戏。

在计算机模拟实现中,可以用-个较大的二维数组表示迷宫,其中元素0表示走得通,元素1表示走不通(受阻),行走路径只考虑水平和垂直方向上的4个方向(上、下、左、右)。图4-9是一个迷宫示意图。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • 适合解决复杂迷宫问题,简单的用算法不至于

广义表

广义表是线性表的推广,也称为列表

它是由n(n≥0)个表元素组成的有限序列,记为:
在这里插入图片描述

在这里插入图片描述

广义表示例

在这里插入图片描述

广义表操作示例

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/68008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

3-Not_only_base/2018网鼎杯

3-Not_only_base 打开code MCJIJSGKPZZYXZXRMUW3YZG3ZZG3HQHCUS 分析: 首先看题知道解密过程中肯定有base解密。 知识点1: Base64字符集: 包含大小写字母(A-Z、a-z)、数字(0-9)以及两个特殊字…

deepseek、qwen等多种模型本地化部署

想要在本地部署deepseek、qwen等模型其实很简单,快跟着小编一起部署吧 1 环境搭建 1.1下载安装环境 首先我们需要搭建一个环境ollama,下载地址如下 :Ollama 点击Download 根据自己电脑的系统选择对应版本下载即可 1.2 安装环境(window为例) 可以直接点击安装包进行安…

02/06 软件设计模式

目录 一.创建型模式 抽象工厂 Abstract Factory 构建器 Builder 工厂方法 Factory Method 原型 Prototype 单例模式 Singleton 二.结构型模式 适配器模式 Adapter 桥接模式 Bridge 组合模式 Composite 装饰者模式 Decorator 外观模式 Facade 享元模式 Flyw…

Idea ⽆ Maven 选项

Idea ⽆ Maven 选项 1. 在 Idea 项⽬上右键2. 选中 Maven 选项 如果在创建 Spring/Spring Boot 项⽬时,Idea 右侧没有 Maven 选项,如下图所示: 此时可以使⽤以下⽅式解决。 1. 在 Idea 项⽬上右键 2. 选中 Maven 选项 选中 Maven 之后&#…

用Deepseek做EXCLE文件对比

背景是我想对比两个PO系统里的一个消息映射,EDI接口的mapping有多复杂懂的都懂,它还不支持跨系统版本对比,所以我费半天劲装NWDS,导出MM到excle,然后问题来了,我需要对比两个excel文件里的内容,…

OpenCV:图像轮廓

目录 简述 1. 什么是图像轮廓? 2. 查找图像轮廓 2.1 接口定义 2.2 参数说明 2.3 代码示例 2.4 运行结果 3. 绘制图像轮廓 3.1 接口定义 3.2 参数说明 3.3 代码示例 3.4 运行结果 4. 计算轮廓周长 5. 计算轮廓面积 6. 示例:计算图像轮廓的面…

在Mac mini M4上部署DeepSeek R1本地大模型

在Mac mini M4上部署DeepSeek R1本地大模型 安装ollama 本地部署,我们可以通过Ollama来进行安装 Ollama 官方版:【点击前往】 Web UI 控制端【点击安装】 如何在MacOS上更换Ollama的模型位置 默认安装时,OLLAMA_MODELS 位置在"~/.o…

CVPR | CNN融合注意力机制,芜湖起飞!

**标题:**On the Integration of Self-Attention and Convolution **论文链接:**https://arxiv.org/pdf/2111.14556 **代码链接:**https://github.com/LeapLabTHU/ACmix 创新点 1. 揭示卷积和自注意力的内在联系 文章通过重新分解卷积和自…

LOCAL_PREBUILT_JNI_LIBS使用说明

LOCAL_PREBUILT_JNI_LIBS使用说明 使用LOCAL_PREBUILT_JNI_LIBS,可用于控制APK集成时,其相关so的集成方式。 比如,用于将APK中的so,抽取出来。 LOCAL_PREBUILT_JNI_LIBS : \lib/arm64-v8a/libNativeCore.so \lib/arm64-v8a/liba…

Java中的object类

1.Object类是什么? 🟪Object 是 Java 类库中的一个特殊类,也是所有类的父类(超类),位于类继承层次结构的顶端。也就是说,Java 允许把任何类型的对象赋给 Object 类型的变量。 🟦Java里面除了Object类,所有的…

uniapp小程序自定义中间凸起样式底部tabbar

我自己写的自定义的tabbar效果图 废话少说咱们直接上代码,一步一步来 第一步: 找到根目录下的 pages.json 文件,在 tabBar 中把 custom 设置为 true,默认值是 false。list 中设置自定义的相关信息, pagePath&#x…

四、GPIO中断实现按键功能

4.1 GPIO简介 输入输出(I/O)是一个非常重要的概念。I/O泛指所有类型的输入输出端口,包括单向的端口如逻辑门电路的输入输出管脚和双向的GPIO端口。而GPIO(General-Purpose Input/Output)则是一个常见的术语&#xff0c…

【Elasticsearch】post_filter

post_filter是 Elasticsearch 中的一种后置过滤机制,用于在查询执行完成后对结果进行过滤。以下是关于post_filter的详细介绍: 工作原理 • 查询后过滤:post_filter在查询执行完毕后对返回的文档集进行过滤。这意味着所有与查询匹配的文档都…

从零开始:用Qt开发一个功能强大的文本编辑器——WPS项目全解析

文章目录 引言项目功能介绍1. **文件操作**2. **文本编辑功能**3. **撤销与重做**4. **剪切、复制与粘贴**5. **文本查找与替换**6. **打印功能**7. **打印预览**8. **设置字体颜色**9. **设置字号**10. **设置字体**11. **左对齐**12. **右对齐**13. **居中对齐**14. **两侧对…

【IoCDI】_Spring的基本扫描机制

目录 1. 创建测试项目 2. 改变启动类所属包 3. 使用ComponentScan 4. Spring基本扫描机制 程序通过注解告诉Spring希望哪些bean被管理,但在仅使用Bean时已经发现,Spring需要根据五大类注解才能进一步扫描方法注解。 由此可见,Spring对注…

通向AGI之路:人工通用智能的技术演进与人类未来

文章目录 引言:当机器开始思考一、AGI的本质定义与技术演进1.1 从专用到通用:智能形态的范式转移1.2 AGI发展路线图二、突破AGI的五大技术路径2.1 神经符号整合(Neuro-Symbolic AI)2.2 世界模型架构(World Models)2.3 具身认知理论(Embodied Cognition)三、AGI安全:价…

【工具变量】中国省级八批自由贸易试验区设立及自贸区设立数据(2024-2009年)

一、测算方式:参考C刊《中国软科学》任晓怡老师(2022)的做法,使用自由贸易试验区(Treat Post) 表征,Treat为个体不随时间变化的虚拟变量,如果该城市设立自由贸易试验区则赋值为1,反之赋值为0&am…

Java进阶总结——集合

Java进阶总结——集合 说明:对于以上的框架图有如下几点说明 1.所有集合类都位于java.util包下。Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口,这两个接口又包含了一些子接口或实…

计算机视觉和图像处理

计算机视觉与图像处理的最新进展 随着人工智能技术的飞速发展,计算机视觉和图像处理作为其中的重要分支,正逐步成为推动科技进步和产业升级的关键力量。 一、计算机视觉的最新进展 计算机视觉,作为人工智能的重要分支,主要研究如…

3.PPT:华老师-计算机基础课程【3】

目录 NO12​ NO34​ NO56​ NO789​ NO12 根据考生文件夹下的Word文档“PPT素材.docx”中提供的内容在PPT.pptx中生成初始的6张幻灯片 新建幻灯片6张→ctrlc复制→ctrlv粘贴开始→新建幻灯片→幻灯片(从大纲)→Word文档注❗前提是:Word文档必须应用标题1、标题2…