栈和队列经典面试题详解

目录

题目一:20. 有效的括号 - 力扣(LeetCode)

题目二:225. 用队列实现栈 - 力扣(LeetCode)

题目三:232. 用栈实现队列 - 力扣(LeetCode)

题目四:622. 设计循环队列 - 力扣(LeetCode)


上一次我们详细讲解了栈和队列的实现,今天我们就来讲一下栈和队列的经典面试题目,以强化我们对栈和队列的理解。话不多说,我们来看题目。

题目一:20. 有效的括号 - 力扣(LeetCode)

这道题目就是一道经典的用栈来解决的问题,我们用c来实现的话就要先实现栈的各种函数,上篇文章我们已经讲过了,这里就不在赘述。

思路:用s指针遍历s,当*s为'('  或 ‘[’ 或  '{' 时进栈,当*s为‘)’或'['或'{'时出栈,然后进行匹配,匹配不成功直接返回false,匹配成功继续匹配,如栈为空且s正好遍历完数组,则返回true。

由于栈具有后进先出的特点,完美的契合了这道题目。代码如下:

这一部分代码是栈的实现,需要注意的一点是要把STDataType改成char,别的和我们之前讲过的一模一样,接下来是接口函数的实现:

大家看一下段代码正不正确,左括号入栈,有括号则出栈匹配,匹配不成功返回false,出while循环代表所有的左括号都匹配成功,返回true。

看似逻辑没有问题,那么我们运行一下代码:

这是什么情况?当s数组只有一个'['时解答错误,遇到错误不要慌张,我们来一步一步的读写代码,来找错误:

*s开始为'['进入while循环,入栈,s++, *s此时为'\0',出while循环,直接返回true。

哦!原来我们漏了一种情况:出了while循环栈不为空,虽然此时已经遍历完了数组,但是栈不为空说明有括号落单没有匹配,所以我们应该在while循环外加上判空的判断,代码如下:

这下代码就正确了。

题目二:225. 用队列实现栈 - 力扣(LeetCode)

这道题目让我们用两个队列来实现一个栈。

栈是后进先出,队列是先进先出,那么怎么用两个队列实现栈呢?

思路:两个队列,q1,q2,保持一个队列不为空(进数据),另一个队列为空(出队列);进行出栈操作时则把不为空的队列的数据剪切到为空的队列中直至剩余最后一个元素停止,然后把删除初始时不为空的队列的最后一个元素,从而完成出栈的模拟。

代码如下:

这段代码在模拟栈的删除时,我们采用了假设法,希望大家能够好好理解理解,这个方法可以一定程度上的优化代码,什么?if...... if?通俗易懂的代码!!!

这段代码我们采用了结构体套结构体的方法,俗称“套娃”:

用obj结构体指针指向MyStack结构体,而MyStack结构体又由结构体Queue q1和Queue q2组成,不要被搞晕了,示意图如下:

还有就是myStackFree函数,要清楚的知道动态开辟的内存都有哪些,可不敢free非动态开辟的内存,也可不敢直接free(obj),这样动态开辟的链表找不到了,不就造成内存泄漏了吗?正确的做法是先调用QueueDestroy释放掉两个链表,然后在释放obj。

怎么说呢,这道题目没有什么实践意义,但是有一定的教学意义,能让我们更好的理解栈和队列。

题目三:232. 用栈实现队列 - 力扣(LeetCode)

这道题目与题目二大同小异,我们创建两个栈:stpush和stpop,stpush负责进入数据,stpop负责出数据。

入数据,就是stpush的入栈操作。又小伙伴会说,不对啊:你这样数据不就进入一个栈了吗?不成了后进先出了吗?

别急,当出数据时,我们和题目二一样进行导数据:把stpush的数据“剪切”到stpop中,这时原来元素的顺序就反过来了,我们在把stpop的栈顶数据删除,就模拟实现了队的出队操作。

思路示意图如下:

入队:

出队:

需要注意的一点是,在进行出队导数据时,我们要先看一下stpop栈中是否有数据,如果有的话就直接删除stpop栈顶数据即可,不可在把stpush中的数据导入进去,否则就会引起顺序错误:

知道了思路后,我们来写代码:

要说的一点是我们在实现出队函数时调用了Peek函数,简化了代码,销毁时还是要注意那块是动态开辟的内存,哪块不是,一定要仔细。

这道题目也是没有实践意义,但是有一定的教学意义。

题目四:622. 设计循环队列 - 力扣(LeetCode)

这是一道非常经典的题目,创建循环队列可以用数组和链表,笔者这次用数组来实现。

我们创建了一个循环队列的结构体,结构体成员变量如上图所示,head和tail可以让我们通过数组下标来访问循环队列收尾元素。

怎么通过数组实现呢?假设队列固定最多有5个元素,当head超过5时让它模5重新指向头即可。

这样就做到首尾相连了

那么当循环队列为满和为空判定条件是什么?

坏事儿了!我们上面的思路队列为满和队列为空时都是head==tail。这该怎么办呢?我们可以额外多开辟一个空间。即队列最大容量为5时我们开辟6个元素的空间。

这样的话我们再来看看队列为满和队列为空时tail和head的关系:

为空:

仍然是head==tail;

为满:

情况二是情况一经过:出队,出队,入队,入队 操作形成的。

这两种情况统一都是:(tail+1)%(k+1)==head。

知道了思路,代码写起来就比较简单了:

入队:入队时要先判断队列满不满,不满则插入数据,插入数据直接往a[tail]位置插入,更新tail的位置:tail=(tail+1)%(k+1).模上k+1的原因是tail有可能表示数组的最后一个位置,加一会变为初始位置。

出队:出队操作,最后要更新head的位置,同样,head可能最开始就表示最后一个位置,也要模上k+1。

总之,就是要注意head和tail的值在0到k这个范围变化。

以上就是全部内容,希望大家能有所收获。

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

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

相关文章

软件压力测试怎么做

随着信息技术的迅猛发展,软件在各行各业的应用越来越广泛,其稳定性、可靠性和性能表现也受到了越来越多的关注。在这样的背景下,软件压力测试显得尤为重要。本文将详细介绍软件压力测试的概念、目的、方法以及实施步骤,帮助读者更…

浅析扩散模型与图像生成【应用篇】(二十五)——Plug-and-Play

25. Plug-and-Play: Diffusion Features for Text-Driven Image-to-Image Translation 该文提出一种文本驱动的图像转换方法,输入一张图像和一个目标文本描述,按照文本描述对输入图像进行转换,得到目标图像。图像转换任务其实本质上属于图像编…

对于接口的安全性测试,这几点你掌握了吗?

接口防刷 1.为什么会有人要刷接口? 牟利:黄牛在 12306 网上抢票再倒卖。 恶意攻击竞争对手:如短信接口被请求一次,会触发几分钱的运营商费用,当量级大了也很可观。 压测:用apache bench 做压力测试。 …

管仲故乡是颍川,何分颍上或颍下

第一仲父管仲,故乡在哪里?依然像许多名人故里一样存在争议,但是这个争议却很不一般,引出了一个大话题。 管子是安徽颍上县人,《史记》记载: “管仲,颍上人也。”颍上县有管鲍祠,是安徽省重点文物…

亚阈值电流镜

相同电流情况下,由于亚阈值区的gm较大,造成由于阈值电压Vth的失配造成的失配会更大,所以要规避过大的gm,选取较大的过驱动电压。 相同电流情况下,W/L的尺寸选的较小一点,或者说L一定时,W不要取得过大。 Q:Vgs一定的情况下,特别小,几乎小于Vth,一定是亚阈值电流镜吗。…

单位内部防泄密策略与技术实践

在信息时代,企业内部数据安全至关重要,尤其是涉及核心竞争力的重要文件,员工的不当操作或恶意泄露都可能给企业带来重大损失。本文将从制度建设、技术防护、以及日常管理三个方面入手,探讨如何构建一套行之有效的内部防泄密体系&a…

yolov8使用与训练步骤

第一:安装miniconda 网址:Index of /anaconda/miniconda/ 登录网址后 在网页按ctrF 输入:搜py38 Miniconda3-py38_22.11.1-1-Windows-x86_64.exe 52.5 MiB 2022-12-23 07:57 下载进行安装 安装过程中记得加环境变量这个项。 第二…

独家|暴雨推出基于国产X86芯片的四路服务器

伴随着智慧计算时代的到来和企业数字化转型的深入,人工智能、大数据、虚拟化等创新技术在应用普及的过程中,也在不断地细分和深化,使得企业的业务系统日趋复杂,数据量、数据类型更加庞大,对计算平台的性能要求“水涨船…

【强化学习】DQN类算法的一些理解

一、DQN算法为什么要使用两个网络? DQN算法通常包含两个网络:一个是评估网络training_network,另一个是目标网络target_network。这两个网络的结构和初始权重是相同的,但它们的权重是不同步更新的。使用两个网络的原因是为了稳定…

十款开源数据集成工具

在大数据作业开发中,数据集成工具是非常重要的一个环节,一个好的数据集成系统从可用性、架构扩展性、底层引擎选型、数据源支持能力等方面都需要一定的考量,在本文中汇总了十款开源的数据集成系统,作者本人在过往的开发过程中&…

Cache基本原理--以TC3xx为例(2)

目录 1.概述 2. Cache映射模式 3.DCache的数据一致性 4.小结 1.概述 上一篇Cache基本原理--以TC3xx为例(1)-CSDN博客,我们聊了Cache基本概念,接下来我们将继续聊Cache映射模式,DCache的数据一致性问题。 2. Cache映射模式 常见的Cache地…

粒子系统技术在AI去衣应用中的创新探索

引言: 随着计算机视觉和人工智能技术的飞速发展,AI去衣技术逐渐走进公众视野。这一技术以其独特的应用前景和技术挑战引起了广泛的关注。在实现衣物去除的同时保持图像质量的关键技术之一,便是粒子系统技术。本文将深入探讨粒子系统技术在AI去…

(C语言)队列实现与用队列实现栈

目录 1.队列 1.1队列的概念及结构 1.2 队列的实际应用联想 1.3队列的实现 2. 队列应用——队列实现栈 主要思路 1.队列 1.1队列的概念及结构 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进…

2022 年高教社杯全国大学生数学建模竞赛-C 题 古代玻璃制品的成分分析与鉴别详解+聚类模型Python代码源码

前言 简单介绍一下我自己:博主专注建模四年,参与过大大小小数十来次数学建模,理解各类模型原理以及每种模型的建模流程和各类题目分析方法。参与过十余次数学建模大赛,三次美赛获得过二次M奖一次H奖,国赛二等奖。**提…

全网最全的Postman接口自动化测试!

该篇文章针对已经掌握 Postman 基本用法的读者,即对接口相关概念有一定了解、已经会使用 Postman 进行模拟请求的操作。 当前环境: Window 7 - 64 Postman 版本(免费版):Chrome App v5.5.3 不同版本页面 UI 和部分…

dbeaver 链接 Oceanbase 数据库,dbeaver安装数据库驱动

新增驱动 提前到Oceanbase官网下载好驱动 1、点击数据库 -> 驱动管理器 -> 新建 2、添加驱动文件 联接数据库 1、选择你添加的驱动 2、测试

Latex问题1

问题 添加bib文件的引用后 \bibliographystyle{IEEEtran} \bibliography{IEEEabrv}之后,出现莫名其妙的错误,如下 IEEEabrv.bib是我的参考文献的bib文件,CCS_1.tex是我的tex文件,bib文件中的内容为 ARTICLE{1,author{Capponi,…

Redis数据结构-RedisObject

1.7 Redis数据结构-RedisObject Redis中的任意数据类型的键和值都会被封装为一个RedisObject,也叫做Redis对象,源码如下: 1、什么是redisObject: 从Redis的使用者的角度来看,⼀个Redis节点包含多个database&#xff…

OpenHarmony 实战开发——使用分布式菜单创建点餐神器

随着社会的进步与发展,科技手段的推陈出新,餐饮行业也在寻求新的突破与变革,手机扫描二维码点餐系统已经成为餐饮行业的未来趋势,发展空间巨大;扫码点餐,是“互联网餐饮”潮流的产物,可以有效地…

学前端网络安全这块还不懂?细说CSRF

什么是CSRF? 举个栗子,比如我们需要在某个博客上删除一个文章,攻击者首先在自己的域构造一个页面,使用了一个img标签,其地址指向了删除博客的链接。攻击者诱使目标用户,也就是博客主访问这个页面&#xff…