数据结构(4)栈和队列

news2024/12/22 20:18:07

一、栈

        栈是一种线性的数据存储结构,由于栈只允许从一端进行数据的插入和删除。因此,栈是先进后出(FILO)的特性。

        系统栈是由系统进行创建和维护的,数据结构中的栈是由自己创建和维护的。

        栈的类型有:满增栈,满减栈,空增栈,空减栈

        满栈和空栈的判断依据:栈顶位置是否有数据,栈顶有数据的称为满栈,栈顶位置没有数据的称为空栈。

        增栈和减栈:增栈是指数据的存放位置有低地址向高地址增长,减栈是指,数据的存放位置有高地址向低地址增长。

 

2.栈的实现

根据栈的实现方式,可以将栈分为顺序栈和链式栈,即使用数组或链表来实现栈

  • 数组实现:使用固定大小的数组,栈的大小在创建时确定。
  • 链表实现:使用链表动态分配内存,栈的大小可以根据需要增长。
3. 栈的操作
  • 入栈(Push):将一个元素添加到栈的顶部。
  • 出栈(Pop):移除并返回栈顶部的元素。
  • 查看栈顶元素(Peek):返回栈顶部的元素,但不移除它。
  • 判断栈是否为空(IsEmpty):检查栈中是否还有元素。
  • 销毁栈(destroy):销毁栈结构,释放申请的堆区空间。

二、队列

        队列也是一种顺序存储数据的结构,它只允许从一端进行数据的插入,另一端进行数据的删除,因此,它遵循先进先出(FIFO)的原则

2. 队列的操作
  • 入队(Enqueue):将一个元素添加到队列的尾部。
  • 出队(Dequeue):移除并返回队列头部的元素。
  • 查看队头元素(Peek):返回队列头部的元素,但不移除它。
  • 判断队列是否为空(IsEmpty):检查队列中是否还有元素。
  • 销毁队列(destroy):销毁队列,释放申请的堆区内存。

3. 队列的实现

队列可以通过数组或链表来实现:

  • 数组实现:使用固定大小的数组,队列的大小在创建时确定。

使用数组实现队列时 会出现假溢出的错误:如果不正确地管理队列的头尾指针,可能会导致队列在逻辑上被认为是满的,即使实际上还有空间可用。

  • 链表实现:使用链表动态分配内存,队列的大小可以根据需要增长。

三、线程邮箱

        线程邮箱(Thread Mailbox)是一种用于线程间通信的机制,允许一个线程将消息或数据发送到另一个线程。

 线程邮箱的工作原理
  • 发送消息:一个线程可以将消息放入邮箱中,通常是通过调用一个发送函数。
  • 接收消息:另一个线程可以从邮箱中读取消息,通常是通过调用一个接收函数。
  • 同步机制:为了确保线程安全,邮箱的实现通常会使用锁或其他同步机制来防止数据竞争。

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

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

相关文章

网络基础入门指南(三)

一、远程管理交换机 1.配置IP地址 远程管理需要通过IP地址访问网络设备交换机的接口,默认无法配置IP地址需要使用虚接口vlan1 2.配置远程登录密码 远程管理需要配置VTY接口VTY是虚拟终端,是一种网络设备远程连接的方式vty 0 4表示可同时打开5个会话 3…

数控纵切自动车床

数控纵切自动车床,作为现代机械加工领域的重要设备,集成了高精度、高效率与自动化等诸多优势。下面,我将从多个方面为您详细介绍这一先进设备。 ‌一、设备概述‌ 数控纵切自动车床,顾名思义,是一种结合了数控技术与纵…

vscode clang-format 格式化

系列文章目录 文章目录 系列文章目录vscode clang-formatOverview1.安装 clang-format2.设置格式化配置文件3.格式化配置文件示例关于作者 vscode clang-format Overview 项目统一格式化clang-formatvscode 1.安装 clang-format 1.vscode中,进行以下操作&#…

C++(二)----类和对象

一、前言 众所周知,C与C语言不同的地方就是,C引入了类和对象,可以在兼容C语言的同时面向对象编程,同时具备了封装、继承、多态三种特点(划重点)。面向对象可以说是C最重要的部分了,而类和对象就…

AnyChart 数据可视化框架

AnyChart 数据可视化框架 AnyChart 是一个灵活的 JavaScript(HTML5、SVG、VML)图表框架,适合任何需要数据可视化的解决方案。 目录 下载并安装开始插件将 AnyChart 与 TypeScript 结合使用将 AnyChart 与 ECMAScript 6 结合使用技术集成贡献…

区块链学习笔记1--比特币

区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。 从狭义上来说:区块链是一种按照时间顺序将数据区块以顺序相连的方式组合成的一种链式数据结构,并以密码学的方式保证的不可篡改和不可伪造的分布式账本。 意思就是…

Zabbix自定义监控项与触发器

当我们需要获取某台主机上的数据时,直接利用 zabbix 提供的模板可以很方便的获得需要的数据,但是有些特别的数据,利用这些现有的模板或监控项是无法实现的,例如网站状态信息的监控、mysql数据库主从状态等信息。这是就需要自己定义键值和监控…

上门家政做饭系统小程序开发概览

上门做饭系统是一种融合了现代科技手段的创新餐饮服务模式,旨在为用户提供便捷且个性化的上门烹饪体验。通过互联网技术,这一系统连接了专业的私人厨师与有需求的家庭或个人,让高品质的餐饮服务更加触手可及。编辑:qawsed2466 核心…

【C++】优先级队列反向迭代器的实现

一、优先级队列: 优先级队列(priority queue)是一种容器适配器, 它默认使用vector作为其底层存储数据的容器,在vector上又使用了堆算法将vector中元素构造成堆的结构,因此priority_queue就是堆,…

Rust 助力无服务器构筑云计算新引擎

引言 今年 Amazon Lambda 迎来了它的第一个十周年。在过去的十年里,无服务器架构改变了软件开发的方式,简化了应用程序的部署和扩展,成为云计算的新引擎。而在众多支持无服务器技术的编程语言中,Rust 以其卓越的安全性和高性能成…

项目管理工作流是什么?项目管理工作流管理实战技巧!

项目管理工作流是指在协作过程中通过限制任务状态的流转进行流程控制的一种方式。项目从启动到完成所经历的一系列有序、可控的步骤和流程,它详细描述了项目执行过程中各项任务和活动的顺序、依赖关系、责任人以及完成标准等,是项目成功执行的重要保障。…

java设计模式 桥接模式

桥接模式(Bridge Pattern)是一种结构型设计模式,旨在将抽象部分与其实现部分分离,使它们都可以独立地变化。桥接模式通过将继承改为组合,实现了在不修改现有类的情况下,动态地切换和扩展抽象类与其具体实现…

Windows 平台安装 Nacos 2.x

环境准备 64 位操作系统,Windows 10 / Linux Centos 7JDK 1.8 安装包下载 安装包下载官方地址:https://github.com/alibaba/nacos/releases 启动 将安装包解压到安装的目录下,改名为 nacos-2.0.4。然后进行到 bin 目录下,打开…

数据集 Look into Person (LIP) 是最流行的单人人体语义分割 >> DataBall

开源数据集 Look into Person (LIP) 是最流行的单人人体语义分割 深度学习 Look into Person (LIP) 是最流行的单人人体分割数据集,它使用像素级注释进行注释,具有19个语义人体部分标签和一个背景标签。LIP包含50,462个带注释的图像,分为30,4…

CAN集线器(工业级、隔离式)

型号: MS-HUB-C 概述 MS-HUB 是一款可通过一路 CAN ,一路 RS-232为主口扩展出 7 路 CAN 从口的工业级光电隔离型 CAN 分配器。可以有效的实现 CAN 网络的中继、扩展与隔离。采用先进的自动流控技术自动侦测CAN 信号流向。MS-HUB 具备光电隔离功能&#x…

UEFI学习笔记(二):edk2构建编译流程

UEFI入门(二):edk2项目编译流程 一、Build流程框架Build的三个阶段:1、Autogen2、Make3、ImageGen 二、编译构建步骤:1. 安装依赖工具2. 初始化构建环境3. 配置工具链和目标4. 定义平台配置5. 构建并编译 三、uefi-too…

怎么通过Java实现和数据库的连接???(附带练习)

JDBC 今日目标 掌握JDBC的的CRUD理解JDBC中各个对象的作用掌握Druid的使用 1,JDBC概述 在开发中我们使用的是java语言,那么势必要通过java语言操作数据库中的数据。这就是接下来要学习的JDBC。 1.1 JDBC概念 JDBC 就是使用Java语言操作关系型数据库的…

STL-stack/queue/deque(容器适配器)

目录 ​编辑 STL-stack 150. 逆波兰表达式求值 stack queue std::stack deque 性能测试 结构 STL-stack 栈的压入、弹出序列_牛客题霸_牛客网输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假。题目…

TESSY创建以及设计一个测试用例

我们以tessy5.1 IDE为例,给大家展示编写一个测试用例的过程。 还不会创建工程的,可以参考以下这篇文章: TESSY创建单元测试或集成测试工程_tessy 集成测试-CSDN博客 接下来我们以这个作为开始状态进行介绍 1、添加源文件 2、添加头文件路径…

存储型XSS漏洞

1.介绍 存储型XSS攻击是一种常见的网络攻击,也称为持久型XSS攻击。与反射型XSS攻击不同,存储型XSS攻击将恶意代码存储在服务器端或数据库中,当其他用户访问该网页时,恶意代码会被执行,导致用户的信息被窃取或造成其他…