4.1.2 栈和队列(二)

文章目录

  • 队列的定义
  • 队列的基本运算
  • 队列的存储结构

队列的定义

在这里插入图片描述
队列先进先出,仅允许一端插入、一端删除
队尾(Rear),插入
队头(Front),删除

队列的基本运算

在这里插入图片描述
队列的基本运算

  • 初始化空队列:initQueue(Q)
  • 判队空:isEmpty(Q)
  • 入队:enQueue(Q,x)元素x加入队尾,更新队尾指针
  • 出队:deQueue(Q)删除队头元素,更新队头指针
  • 读队头元素:frontQueue(Q)返回队头元素,但不修改队头指针

队列的存储结构

在这里插入图片描述
队列有顺序存储、链式存储两种存储结构。

  • 顺序存储:用地址连续的存储单元存储。需要设置队头指针、队尾指针。队列的容量预先申请,是有限的。为充分利用队列空间,将顺序队列想象成环状结构,称为循环队列。
  • 循环队列通过对队列容量取模实现。由于队列为空、满时,队头和队尾指针都在同样的位置。为了区分队列是空是满,有2种方法。一种是使用一个标志域,专用于描述队列空、满。另一种是牺牲一个元素空间,约定“队尾指针的下一个位置是队头”表示队满,队头队尾指针相同时表示队空。
  • 链式存储:用链表存储队列,除队头、队尾外,使用一个头结点,其指针域指向队头。

队列常应用于需要排队的场合,例如打印任务的打印队列,离散事件的计算机模拟。

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

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

相关文章

【HeadFirst系列之HeadFirst设计模式】第1天之HeadFirst设计模式开胃菜

HeadFirst设计模式开胃菜 前言 从今日起,陆续分享《HeadFirst设计模式》的读书笔记,希望能够帮助大家更好的理解设计模式,提高自己的编程能力。 今天要分享的是【HeadFirst设计模式开胃菜】,主要介绍了设计模式的基本概念、设计模…

Oracle数据库如何找到 Top Hard Parsing SQL 语句?

有一个数据库应用程序存在过多的解析问题,因此需要找到产生大量硬解析的主要语句。 什么是硬解析 Oracle数据库中的硬解析(Hard Parse)是指在执行SQL语句时,数据库需要重新解析该SQL语句,并创建新的执行计划的过程。这…

【GBT32960协议学习系列】GBT 32960协议的背景、目的和适用范围

GBT 32960协议的背景、目的和适用范围 1. GBT 32960协议的背景 GBT 32960是中国国家标准,全称为《电动汽车远程服务与管理系统技术规范》。该标准由中国国家标准化管理委员会发布,旨在规范电动汽车远程服务与管理系统的技术要求,确保电动汽车…

软件工程期末复习(一)

题目复习 单选题 软件产品的核心特性是什么? A. 物质性 B. 逻辑性 C. 可复制性 D. 消耗性 正确答案:B 单选题 在软件开发过程中,哪个环节最接近于传统制造业中的“生产”过程? A. 需求分析 B. 编码 C. 测试 D. 研制&#xff08…

蓝桥杯备赛:C++基础,顺序表和vector(STL)

目录 一.C基础 1.第一个C程序: 2.头文件: 3.cin和cout初识: 4.命名空间: 二.顺序表和vector(STL) 1.顺序表的基本操作: 2.封装静态顺序表: 3.动态顺序表--vector:…

创建并配置华为云虚拟私有云

目录 私有云 创建虚拟私有云 私有云 私有云是一种云计算模式,它将云服务部署在企业或组织内部的私有基础设施上,仅供该企业或组织内部使用,不对外提供服务.私有云的主要特点包括: 私密性:私有云的资源(如…

Rust中的Option枚举快速入门

引言 Option是Rust编程语言中的一个枚举类型,用于表示一个值可能存在也可能不存在(即我们熟知的null)的情况。它是Rust处理可能为空的值的主要方式,有助于避免空指针异常等问题。 Option介绍 Option枚举定义在标准库中,其源码如下所示&…

OWASP ZAP之API 请求基础知识

ZAP API 提供对 ZAP 大部分核心功能的访问,例如主动扫描器和蜘蛛。ZAP API 在守护进程模式和桌面模式下默认启用。如果您使用 ZAP 桌面,则可以通过访问以下屏幕来配置 API: Tools -> Options -> API。 ZAP 需要 API 密钥才能通过 REST API 执行特定操作。必须在所有 …

音视频入门基础:MPEG2-PS专题(3)——MPEG2-PS格式简介

一、引言 本文对MPEG2-PS格式进行简介。 进行简介之前,请各位先下载MPEG2-PS的官方文档。ITU-T和ISO/IEC都分别提供MPEG2-PS的官方文档。但是ITU提供的文档是免费的,ISO/IEC是付费的,所以我们主要阅读ITU提供的官方文档,比如较新…

云打印之菜鸟打印组件交互协议

菜鸟打印组件交互协议相关介绍如下: 1、打印组件下载地址 https://page.cainiao.com/waybill/cloud_printing/home.html 2、socket连接商品 如果是http的话,端口是13529 socket new WebSocket(ws://localhost:13528); 如果是https的话&#xff0c…

CPT203 Software Engineering 软件工程 Pt.3 系统建模(中英双语)

文章目录 5. System Modeling(系统建模)5.1 Context models(上下文模型)5.2 Interaction models(交互模型)5.2.1 Use case modeling(用况建模)5.2.2 Sequence diagram(顺…

【HDU】1090 A+B for Input-Output Practice (II)

1090 AB for Input-Output Practice (II) :题目有N个输入组,接下来依次给出N个输入组数据 Problem Description Your task is to Calculate a b.Input Input contains an integer N in the first line, and then N lines follow. Each line consists of a pair of…

GNU链接器简介-2

GNU链接器简介-2 1 简单链接器脚本命令1.1 Setting the Entry Point1.2 Commands Dealing with Files2.3 Commands Dealing with Object File Formats2.4 Assign alias names to memory regions2.5 Other Linker Script Commands 3 5Assigning Values to Symbols3.1 Simple Ass…

AWS DMS基础知识

1.AWS Database Migration Service (DMS) 概述 AWS DMS 定义:它能助力以最少停机时间把数据库迁移至 AWS,支持同构(如 Oracle 到 Oracle)、异构(如 Oracle 到 PostgreSQL )迁移。常…

Ubuntu 安装英伟达显卡驱动问题记录

建议 无论什么版本的系统,都建议从官网下载驱动,一般下载下来后是一个 run 开头的可执行程序,直接在命令行执行就可以。 之所以这么建议,是因为使用 包管理工具安装的驱动一般都是社区版本,社区版本的问题就是没有签…

什么是Kafka的重平衡机制?

Kafka 的重平衛机制是指在消费者组中新增或删除消费者时,Kafka 集群会重新分配主题分区给各个消费者,以保证每个消费者消费的分区数量尽可能均衡。 重平衡机制的目的是实现消费者的负载均衡和高可用性,以确保每个消费者都能够按照预期的方式…

Nginx——反向代理(三/五)

目录 1.Nginx 反向代理1.1.Nginx 反向代理概述1.2.Nginx 反向代理的配置语法1.2.1.proxy_pass1.2.2.proxy_set_header1.2.3.proxy_redirect 1.3.Nginx 反向代理实战1.4.Nginx 的安全控制1.4.1.如何使用 SSL 对流量进行加密1.4.2.Nginx 添加 SSL 的支持1.4.3.Nginx 的 SSL 相关指…

VBA(Visual Basic for Applications)编程|excel|一系列网址或文件路径快速转换为可点击的超链接

很多时候,我们需要把导入的数据某一列转换成超链接,比如URL形式的列。 那么,大批量的情况下,无疑一个个手动点击是非常愚蠢的办法,这个时候我们就需要VBA编程来编写宏,通过编写宏来简化这些手动操作并不现…

【C++】图像模糊处理题目详解与实现

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目描述题目内容输入格式输出格式示例输入:输出: 💯题目分析问题拆解 💯我的做法代码实现代码分析 💯老师的做法…

在 Ubuntu 22.04 上部署 AppArmor 应用安全教程

在这篇教程中,我们将为你设置 AppArmor 以增强应用程序的安全性。 AppArmor 是一个 Linux 安全模块,允许你限制各个程序的功能。通过强制执行强制访问控制策略,AppArmor 增强了你的应用程序和系统的安全性。 AppArmor 是一个易于使用的 Lin…