CSP初赛知识学习计划(第六天)

探秘数据结构:栈与队列

在计算机科学的奇妙世界里,栈和队列宛如两颗璀璨的明珠,它们作为基础的数据结构,在众多复杂的算法与程序流程把控中发挥着关键作用。

一、栈 —— 后进先出的 “数据桶”

(一)概念解析

栈,形象地来说,就像是一个底部封闭、顶部开口的竖直容器,数据元素如同一个个小球依次放入其中。新的数据项只能从栈顶加入,也只能从栈顶取出,这就形成了它独特的 “后进先出”(Last In First Out,简称 LIFO)特性。

(二)基本操作

  1. 入栈(Push):当一个新元素要进入栈时,它被放置在栈顶的位置,栈顶指针随之向上移动一位,指向新的栈顶元素。例如,若栈初始为空,依次将元素 5、8、12 入栈,此时栈顶元素为 12,栈内元素自底向上依次是 5、8、12。
  1. 出栈(Pop):从栈顶移除一个元素,栈顶指针向下移动一位,指向原来栈顶下方的元素。接着上面的例子,若执行一次出栈操作,12 被取出,栈顶元素变为 8。

(三)应用领域 —— 表达式求值

在算术表达式求值中,栈展现出强大的功能。对于中缀表达式,如 “3 + 4 * 2”,计算机为了准确计算,需借助两个栈 —— 操作数栈和运算符栈。扫描表达式时,数字直接入操作数栈;运算符则根据优先级判断,若当前运算符优先级高于栈顶运算符(初始栈顶为一个低优先级的特殊符号),入运算符栈,否则从操作数栈弹出两个数,结合运算符栈顶运算符进行计算,结果再入操作数栈。如此往复,最终得出表达式的值,整个过程精准有序,全靠栈对操作数与运算符的巧妙管理。

二、队列 —— 先进先出的 “排队模型”

(一)概念明晰

队列仿若日常生活中的排队场景,人们在队尾依次加入,从队首依次离开,遵循 “先进先出”(First In First Out,简称 FIFO)原则。在计算机里,它是一种线性表,数据元素从一端进入,从另一端出去。

(二)基本操作

  1. 入队(Enqueue):新元素被添加到队列的末尾,队列长度增加。例如,有一个初始为空的队列,依次将元素 10、15、20 入队,它们在队列中按入队顺序排列,即 10 在队首,20 在队尾。
  1. 出队(Dequeue):队首元素被移除,队列长度减 1,后续元素向前移动一位。接着上述例子,执行一次出队操作,10 被取出,此时队首元素变为 15。

(三)实际应用

  1. 任务调度:在操作系统中,多个进程等待 CPU 处理时,它们按请求顺序排成队列。CPU 按照先进先出原则,依次从队列头部选取进程运行一段时间片,确保公平性与资源合理分配,避免某些进程长时间 “饥饿” 等待。
  1. 消息缓冲:即时通讯软件里,大量消息从不同客户端发送至服务器。服务器将这些消息按接收顺序存入队列,再逐个处理转发,保证消息顺序与发送顺序一致,用户接收时逻辑连贯,聊天体验流畅。

无论是栈的后进先出,还是队列的先进先出,它们虽规则简单,却在各自擅长的领域熠熠生辉,为计算机解决复杂问题、优化流程提供了不可或缺的基础支撑,持续推动着数字时代的蓬勃发展。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Mac-docker配置

1.配置的文件路径 cd ~/.docker (base) zhangyaweimacbookair .docker % ls buildx cli-plugins config.json contexts daemon.json desktop-build mutagen run (base) zhangyaweimacbookair .docker % cat daemon.json## 重启docker服务 sudo systemctl daemon-reload sudo…

PHP进阶-在Ubuntu上搭建LAMP环境教程

本文将为您提供一个在Ubuntu服务器上搭建LAMP(Linux, Apache, MySQL, PHP)环境的完整指南。通过本文,您将学习如何安装和配置Apache、MySQL、PHP,并将您的PHP项目部署到服务器上。本文适用于Ubuntu 20.04及更高版本。 一、系统更新…

Elasticsearch(看这一篇就够了)

目录: Elasticsearch介绍正排索引和倒排索引Elasticsearch安装安装ES服务安装服务安装kibana 索引操作创建索引查询索引库修改索引库删除索引库 Elasticsearch常用操作文档操作新增文档查询文档删除文档根据id批量查询文档查询所有文档修改文档部分字段 域的属性分词…

嵌入式技术之Linux(Ubuntu) 一

一、Linux入门 1.硬件和操作系统以及用户的关系 一个传感器,获得数据后,需要向服务器发送数据。传感器传数据给上位机。 上位机需要一个程序来接收数据,那么这个上位机是什么机器? 我们的笔记本电脑就可以当成上位机。 两个手…

【实用技能】如何使用 .NET C# 中的 Azure Key Vault 中的 PFX 证书对 PDF 文档进行签名

TX Text Control 是一款功能类似于 MS Word 的文字处理控件,包括文档创建、编辑、打印、邮件合并、格式转换、拆分合并、导入导出、批量生成等功能。广泛应用于企业文档管理,网站内容发布,电子病历中病案模板创建、病历书写、修改历史、连续打…

oracle闪回恢复数据:(闪回查询,闪回表,闪回库,回收站恢复)

oracle的闪回查询,可以查询提交在表空间的闪回数据,并可以还原所查询的数据,用于恢复短时间内的delele 或者 update 误操作,非常方便,缺点是只能恢复大概几小时内的数据。 文章目录 概要闪回查询恢复数据的主要方法包括…

开放词汇检测新晋SOTA:地瓜机器人开源DOSOD实时检测算法

在计算机视觉领域,目标检测是一项关键技术,旨在识别图像或视频中感兴趣物体的位置与类别。传统的闭集检测长期占据主导地位,但近年来,开放词汇检测(Open-Vocabulary Object Detection-OVOD 或者 Open-Set Object Detec…

【网络协议】静态路由详解

网络中的路由器通过以下两种方式之一发现远程网络: 静态配置路由动态路由协议 在本文,我们将学习关于静态路由的各种概念,例如如何配置静态路由、路由表如何进行决策、路由接口等相关知识。 文章目录 引言直连网络静态路由路由表原则原则1原…

(长期更新)《零基础入门 ArcGIS(ArcScene) 》实验七----城市三维建模与分析(超超超详细!!!)

城市三维建模与分析 三维城市模型已经成为一种非常普遍的地理空间数据资源,成为城市的必需品,对城市能化管理至关重要。语义信息丰富的三维城市模型可以有效实现不同领域数据与IS相信息的高层次集成及互操作,从而在城市规划、环境模拟、应急响应和辅助决策等众多领域公挥作用、…

计算机网络--路由器问题

一、路由器问题 1.计算下一跳 计算机网络--根据IP地址和路由表计算下一跳-CSDN博客 2.更新路由表 计算机网络--路由表的更新-CSDN博客 3.根据题目要求给出路由表 4.路由器收到某个分组,解释这个分组是如何被转发的 5.转发分组之路由器的选择 二、举个例子 …

通过Android Studio修改第三方jar包并重新生成jar包

最近接手了来自公司其他同事的一个Unity项目,里面有一个封装的jar包要改动一下,无奈关于这个jar包的原工程文件丢失了,于是自己动手来修改下jar包,并做下记录。 一、导入第三方jar包 1、新建项目EditJarDemo(项目名随便取) 2、新建libs文件夹,把你要修改的third.jar 复制…

33.3K 的Freqtrade:开启加密货币自动化交易之旅

“ 如何更高效、智能地进行交易成为众多投资者关注的焦点。” Freqtrade 是一款用 Python 编写的免费开源加密货币交易机器人。它就像一位不知疲倦的智能交易助手,能够连接到众多主流加密货币交易所,如 Binance、Bitmart、Bybit 等(支…

计算机网络 (26)互联网的路由选择协议

一、路由选择协议的基本概念 路由选择协议是计算机网络中用于确定数据包在网络中传输路径的一种协议。它帮助路由器构建和维护路由表,以便根据目的地址将数据包转发到正确的下一跳路由器。路由选择协议分为静态路由选择协议和动态路由选择协议两大类。 二、静态路由…

【MySQL实战】Centos安装MySQL

在CentOS上安装MySQL以及进行性能分析:2种方式,第一种直接装;第二种用docker安装: 直接安装MySQL 首先,更新系统软件包列表: sudo yum update然后,安装MySQL服务器: sudo yum in…

centOS7

特殊权限 set_uid 赋予所有者身份 chmod us 文件 set_gid 赋予所有组身份 chmod gs 文件/目录 sticky_bit 防火墙 firewall-cmd 开启端口 firewall-cmd --zonepublic --add-port8080/tcp --permanent 重启防火墙 systemctl restart firewalld 查看开启的所有端口 fi…

Java后端开发单元测试

测试概览 测试是用于促进鉴定软件正确性、完整性、安全性和软件质量的过程。在开发的过程中测试是必不可少的,测试一般分为四个阶段:单元测试,集成测试,系统测试,验收测试;对于后端开发人员而言&#xff0…

LAMP搭建

LAMP搭建 引子:本篇文章为LAMP的搭建流程,其中L(Ubuntu)、A(Apache)、M(Mysql)、P(PHP)。 一、L → Ubuntu Step 1:在Vmware Workstation中使…

LabVIEW 系统诊断

LabVIEW 系统诊断是指通过各种工具和方法检测、评估、分析和解决 LabVIEW 程序和硬件系统中可能存在的故障和性能问题。系统诊断不仅涵盖软件层面的调试与优化,还包括硬件交互、数据传输、实时性能等方面的检查和分析。一个成功的系统诊断能够显著提升LabVIEW应用程…

基于 GEE 提取白莲种植范围

目录 1 方法原理 1.1 步骤一 1.2 步骤二 1.3 步骤三 1.4 步骤四 2 完整代码 3 运行结果 近年来,随着乡村振兴战略的提出,我国的农业种植模式呈现出多元化的趋势。白莲具有易种植、经济效益高的特点,由此被广泛种植,本文介绍…

el-table 自定义表头颜色

第一种方法&#xff1a;计算属性 <template><div><el-table:data"formData.detail"border stripehighlight-current-row:cell-style"{ text-align: center }":header-cell-style"headerCellStyle"><el-table-column fixed…