栈与队列:常见的线性数据结构
栈(Stack)和队列(Queue)是计算机科学中常见的线性数据结构,它们在许多算法和编程场景中发挥着重要作用。它们的不同特点和用途使得它们适用于不同的问题和应用。
栈(Stack)
栈,作为一种线性数据结构,其特点在于遵循后进先出(Last-In-First-Out,LIFO)的原则。这意味着最后一个进入栈的元素将第一个被弹出,而最先进入的元素将成为最后被弹出的。这一奇妙的特性使得栈在许多实际问题中得到广泛应用。
回想一下现实生活中的例子,我们可以将栈类比为堆叠的盘子。当我们往堆叠中放入一叠盘子时,最后放入的盘子会在顶部,而取出盘子时也是从顶部开始取。这种方式保证了后放入的盘子最先被取走,而先放入的盘子则被压在下面。
栈的操作
栈支持以下两种主要操作:
- 入栈(Push):将元素放入栈的顶部。
- 出栈(Pop):从栈的顶部取出元素。
栈的一个重要特性是,只能访问栈顶的元素,其他元素都无法直接访问。这种特性使得栈在许多问题中都有用处,如逆波兰表达式求值、括号匹配、函数调用的调用栈等。
括号匹配
这里我们举一个括号字符串,需要判断其中的括号是否匹配。
#include <iostream>
#include <stack>
#include <string>bool isBracketMatched(const std::string& expression) {std::stack<char> brackets; // 创建字符栈for (char ch : expression) {if (ch == '(' || ch == '[' || ch == '{') {brackets.push(ch); // 将左括号入栈} else if (ch == ')' || ch == ']' || ch == '}') {if (brackets.empty()) {return false; // 出现未匹配的右括号}char topBracket = brackets.top(); // 获取栈顶元素brackets.pop(); // 弹出栈顶元素if ((ch == ')' && topBracket != '(') ||(ch == ']' && topBracket != '[') ||(ch == '}' && topBracket != '{')) {return false; // 括号不匹配}}}return brackets.empty(); // 检查是否还有未匹配的括号
}int main() {std::string expression = "{[()]()}";if (isBracketMatched(expression)) {std::cout << "括号匹配。" << std::endl;} else {std::cout << "括号不匹配。" << std::endl;}return 0;
}
队列(Queue)
队列是另一种具有特定操作规则的线性数据结构,遵循先进先出的原则。队列可以想象成排队的人,先到先得,后到后得。
与栈不同,队列是另一种常见的线性数据结构,它遵循先进先出(First-In-First-Out,FIFO)的原则。这意味着最早进入队列的元素将最先被弹出,而最后进入的元素将成为最后被弹出的。这一特性使得队列在诸多场景中都能发挥出色的效果。
在日常生活中,队列的例子随处可见。想象一下排队购买电影票的场景:最早来排队的人会最早买到票,而后来的人则会排在后面依次等候。这种先来先服务的原则保证了排队者的公平性。
在计算机领域,队列同样扮演着重要角色。操作系统中的任务调度、打印队列管理以及网络数据传输等领域都广泛使用队列来管理任务和数据。例如,操作系统会使用队列来管理待执行的任务,确保每个任务都能按照顺序得到执行。
队列的操作
队列支持以下两种主要操作:
- 入队(Enqueue):将元素放入队列的末尾。
- 出队(Dequeue):从队列的开头取出元素。
队列的一个关键特点是,只有队列头部的元素可以被访问和移除,而队列尾部的元素只能被插入。队列在许多应用中都很有用,如任务调度、广度优先搜索等。
任务调度
这里笔者举一个任务调度的案例,有多个任务需要执行,但每个任务需要等待一段时间才能执行。
#include <iostream>
#include <queue>
#include <string>void scheduleTasks(const std::vector<std::string>& tasks, int delay) {std::queue<std::string> taskQueue; // 创建字符串队列for (const std::string& task : tasks) {taskQueue.push(task); // 将任务入队}while (!taskQueue.empty()) {std::string currentTask = taskQueue.front(); // 获取队头任务taskQueue.pop(); // 出队std::cout << "执行任务:" << currentTask << std::endl;if (!taskQueue.empty()) {std::cout << "等待 " << delay << " 秒..." << std::endl;// 模拟延迟(以秒为单位)// 在实际场景中,可能会使用 sleep 函数// std::this_thread::sleep_for(std::chrono::seconds(delay));}}
}int main() {std::vector<std::string> tasks = {"任务1", "任务2", "任务3", "任务4"};int delay = 2;scheduleTasks(tasks, delay);return 0;
}
总结
栈和队列作为常见的线性数据结构,分别以后进先出和先进先出的原则为基础,广泛应用于算法、编程和软件开发等领域。它们的独特特性使得它们能够优雅地解决各种问题,从模拟现实场景到优化算法流程。通过深入理解栈和队列的原理和应用,我们能够更加灵活地运用它们来解决复杂的计算机科学问题,为软件开发和算法设计带来更多可能性。
相关文章:
栈与队列:常见的线性数据结构
栈(Stack)和队列(Queue)是计算机科学中常见的线性数据结构,它们在许多算法和编程场景中发挥着重要作用。它们的不同特点和用途使得它们适用于不同的问题和应用。 栈(Stack) 栈,作为…...
android framework之AMS的启动管理与职责
AMS是什么? AMS管理着activity,Service, Provide, BroadcastReceiver android10后:出现ATMS,ActivityTaskManagerService:ATMS是从AMS中抽出来,单独管理着原来AMS中的Activity组件 。 现在我们对AMS的分析,也就包含对…...
Decoupling Knowledge from Memorization: Retrieval-augmented Prompt Learning
本文是LLM系列的文章,针对《Decoupling Knowledge from Memorization: Retrieval 知识与记忆的解耦:检索增强的提示学习 摘要1 引言2 提示学习的前言3 RETROPROMPT:检索增强的提示学习4 实验5 相关实验6 结论与未来工作 摘要 提示学习方法在…...

腾讯云coding平台平台inda目录遍历漏洞复现
前言 其实就是一个python的库可以遍历到,并不能遍历到别的路径下,后续可利用性不大,并且目前这个平台私有部署量不多,大多都是用腾讯云在线部署的。 CODING DevOps 是面向软件研发团队的一站式研发协作管理平台,提供…...
无法正常访问服务器
网络原因,本地网络:解决办法:检查本地网络是否正常,访问外网是否流畅。机房网络:通过路由追踪查看是否中间有 节点不通,确定是线路出现丢包。 远程连接,检查远程连接是否启用以及远程计算机上的…...

解决css英文内容不自动换行的问题
解决css英文内容不自动换行的问题 这里主要是针对CMS后台管理系统添加进入数据库,再抓取出来前端显示的英文不换行的问题的情况 1.一般常见的就是英文不自动换行,或者英文换行单词背截断的问题。 这种处理方法通过前端样式就可以解决,方法网…...
python语言学习
序言 此系列用于总结python语言的相关知识点,用于帮助自己和有缘人查阅 1、python基本数据类型 python基本数据类型 – 字符串...

1. 深度学习介绍
1.1 AI地图 ① 如下图所示,X轴是不同的模式,最早的是符号学,然后概率模型、机器学习。Y轴是我们想做什么东西,感知是我了解这是什么东西,推理形成自己的知识,然后做规划。 ② 感知类似我能看到前面有个屏…...

【现场问题】oracle 11g 和12c 使用jdbc链接,兼容的问题
oracle不同版本 问题是什么寻找解决方式首先Oracle的jdbc链接有几种形式?Oracle 11g的链接是什么呢Oracle 12C的链接是什么呢我的代码是哪种!?发现问题没 解决问题代码 问题是什么 项目上建立Oracle数据源,以前大部分都是,11g的…...

嵌入式底层驱动需要知道的基本知识
先说结论,能,肯定能,必须能! 但是,问题重点在于坚持,程序员这一行 ,下班回家一般都要10点了,再刷两个小时枯燥的学习视频,我想大多数人是坚持不下来的。 但是ÿ…...

《软件开发的201个原则》阅读笔记 120-161条
目录 使用有效的测试完成度标准 原则122 达成有效的测试覆盖 原则123 不要在单元测试之前集成 原则 124 测量你的软件 原则125 分析错误的原因 对错不对人 原则127 好的管理比好的技术更重要 使用恰当的方法 原则 129 不要相信你读到的一切 原则130 理解客户的优先级 原…...

JVM——类加载与字节码技术—类文件结构
由源文件被编译成字节码文件,然后经过类加载器进行类加载,了解类加载的各个阶段,了解有哪些类加载器,加载到虚拟机中执行字节码指令,执行时使用解释器进行解释执行,解释时对热点代码进行运行期的编译处理。…...
C语言学习之main函数两个参数的应用
main函数的两个参数: int main(int argc, char const *argv[]) {/* code */return 0; }参数argc:表示在执行程序时,在终端所输入参数的个数,包括可执行文件的名称;参数argv:1.本质上是一个字符型指针数组;2.用于获取指…...

本地部署 Stable Diffusion(Windows 系统)
相对于使用整合包,手动在 Windows 系统下本地部署 Stable Diffusion Web UI(简称 SD-WebUI),更能让人了解一些事情的来龙去脉。 一、安装前置软件:Python 和 Git 1、安装 Python for windows。 下载地址 https://www.p…...

Java源码分析(二)Double
本篇是源码分析的第二篇,上篇我们一起分析了Integer类的源码,本篇一起学习下Double类的源码,看下其实现。 一、Double类图 首先,相比Integer,Double类的源码只有1000行代码。如下是Integer及其关联类/接口的类图&#…...

文件上传漏洞之条件竞争
这里拿upload-labs的第18关做演示 首先先看代码 $is_upload false; $msg null;if(isset($_POST[submit])){$ext_arr array(jpg,png,gif);$file_name $_FILES[upload_file][name];$temp_file $_FILES[upload_file][tmp_name];$file_ext substr($file_name,strrpos($file_…...

javacv基础04-图像色彩空间转换函数Imgproc.cvtColor()(彩图转灰度图示例)
opencv python 实现方式参考 opencv-19 图像色彩空间转换函数cv2.cvtColor() javacv 中的函数 Imgproc.cvtColor(image, grey, Imgproc.COLOR_BGR2GRAY); 参数说明: image: 原始图像新灰度图转换参数:多种转换方式参考上面链接地址内容 javacv 实现方式…...

Spring Boot进阶(60):5种判断线程池任务是否全部完成的方案 | 实用技巧分享!
1. 前言🔥 多线程编程在现代软件开发中非常常见且重要,而线程池是多线程编程的常用技术。在使用线程池时,通常需要判断线程池中的任务是否全部完成,以便决定程序继续执行的下一步操作。本文将介绍5种判断线程池任务是否全部完成的…...
Git相关介绍和操作
Git 是一个版本控制系统,它可以记录代码的变更历史,并允许多人协同开发。下面是 Git 的基本概念和使用方式: 仓库(Repository):Git 仓库用于存储代码的版本历史,包括代码变更、注释、作者、时间…...
IDEA配置热启动
1.背景 开发过程中,当写完一个功能我们需要运行应用程序测试,可能这个小功能中存在多个小bug,我们需要改正后重启服务器,这无形之中拖慢了开发的速度增加了开发时间,SpringBoot提供了spring-boot-devtools,…...

多云管理“拦路虎”:深入解析网络互联、身份同步与成本可视化的技术复杂度
一、引言:多云环境的技术复杂性本质 企业采用多云策略已从技术选型升维至生存刚需。当业务系统分散部署在多个云平台时,基础设施的技术债呈现指数级积累。网络连接、身份认证、成本管理这三大核心挑战相互嵌套:跨云网络构建数据…...
Auto-Coder使用GPT-4o完成:在用TabPFN这个模型构建一个预测未来3天涨跌的分类任务
通过akshare库,获取股票数据,并生成TabPFN这个模型 可以识别、处理的格式,写一个完整的预处理示例,并构建一个预测未来 3 天股价涨跌的分类任务 用TabPFN这个模型构建一个预测未来 3 天股价涨跌的分类任务,进行预测并输…...
linux 错误码总结
1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...
【算法训练营Day07】字符串part1
文章目录 反转字符串反转字符串II替换数字 反转字符串 题目链接:344. 反转字符串 双指针法,两个指针的元素直接调转即可 class Solution {public void reverseString(char[] s) {int head 0;int end s.length - 1;while(head < end) {char temp …...
【HTML-16】深入理解HTML中的块元素与行内元素
HTML元素根据其显示特性可以分为两大类:块元素(Block-level Elements)和行内元素(Inline Elements)。理解这两者的区别对于构建良好的网页布局至关重要。本文将全面解析这两种元素的特性、区别以及实际应用场景。 1. 块元素(Block-level Elements) 1.1 基本特性 …...

使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...
鸿蒙DevEco Studio HarmonyOS 5跑酷小游戏实现指南
1. 项目概述 本跑酷小游戏基于鸿蒙HarmonyOS 5开发,使用DevEco Studio作为开发工具,采用Java语言实现,包含角色控制、障碍物生成和分数计算系统。 2. 项目结构 /src/main/java/com/example/runner/├── MainAbilitySlice.java // 主界…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)
上一章用到了V2 的概念,其实 Fiori当中还有 V4,咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务),代理中间件(ui5-middleware-simpleproxy)-CSDN博客…...

Yolov8 目标检测蒸馏学习记录
yolov8系列模型蒸馏基本流程,代码下载:这里本人提交了一个demo:djdll/Yolov8_Distillation: Yolov8轻量化_蒸馏代码实现 在轻量化模型设计中,**知识蒸馏(Knowledge Distillation)**被广泛应用,作为提升模型…...
Java + Spring Boot + Mybatis 实现批量插入
在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法:使用 MyBatis 的 <foreach> 标签和批处理模式(ExecutorType.BATCH)。 方法一:使用 XML 的 <foreach> 标签ÿ…...