栈和队列经典面试题详解

目录

题目一: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这个范围变化。

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

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

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

相关文章

【董晓算法】动态规划之线性DP问题

前言: 本系列是看的B站董晓老师所讲的知识点做的笔记 董晓算法的个人空间-董晓算法个人主页-哔哩哔哩视频 (bilibili.com) 树塔-记忆化搜索 特点(前提):从上向下的累加和是不能重复使用的,从下向上的累加和是可以重…

抖音电商发展受限,视频号反而成了短视频电商风口?这是为什么?

哈喽~我是电商月月 抖音小店发展的如火如荼间,视频号也正式推出了自己的电商平台 视频号小店的推出,引的众多商家讨论 很多人都觉得视频号的流量比不过抖音,玩互联网的人群【年轻群体】都集中在抖音上了,有抖音在,视…

动态规划算法:⼦序列问题(数组中不连续的⼀段)

例题一 解法(动态规划): 算法思路: 1. 状态表⽰: 对于线性 dp ,我们可以⽤「经验 题⽬要求」来定义状态表⽰: i. 以某个位置为结尾,巴拉巴拉; ii. 以某个位置…

【EasyX】快速入门——静态图形篇

1.基本说明 EasyX 是针对 C 的图形库,可以帮助 C/C 初学者快速上手图形和游戏编程。 比如,可以基于 EasyX 图形库很快的用几何图形画一个房子,或者一辆移动的小车,可以编写俄罗斯方块、贪吃蛇、黑白棋等小游戏,可以练…

类和对象的特性

1.检查错误。 代码&#xff1a; #include <iostream>using namespace std;class Time { private:/* data */ public:Time(/* args */);~Time();void set_time(void);void show_time(void);int hour;int minute;int sec; };Time::Time(/* args */) { }Time::~Time() { }T…

Java环境搭配(一)JDK下载以及介绍、path环境变量配置

目录 JDK Development Kit &#xff08;JDK&#xff09; 下载 JDK介绍 &#xff1a; JDK 包括以下主要组件 配置path环境变量 在cmd上打印Helloworld JDK Development Kit &#xff08;JDK&#xff09; 下载 下载官方地址 www.oracle.com 进入网址后&#xff1a; 点击产…

指针在函数的应用(C++)

一、传递地址 实参传递进函数体内后&#xff0c;生成的是实参的副本&#xff0c;在函数内改变副本的值并不影响实参。指针传递参数时&#xff0c;指针变量产生了副本&#xff0c;但副本与原变量指向的内存区域是同一个。改变指针副本指向的变量&#xff0c;就是改变原指针变量指…

快速查看字符对应的ASCII码

1、借助gdb查看 打印字符串用双引号括起来打印单个字符用单引号括起来x 表示十六机制d 表示十进制t 表示二进制 2、借助二进制查看软件 第一步&#xff1a;把要查看的字符保存到文本文件中第二步&#xff1a;借助二进制查看工具&#xff08;比如&#xff1a;Hex Editor Neo&am…

字节跳动在2024年春季火山引擎Force原动力大会上隆重推出了“豆包大模型”家族

此次大会以AI为主题&#xff0c;聚焦大模型的应用与发展&#xff0c;旨在引领AI技术的落地和推动各行各业的数字化转型。 字节跳动官网&#xff1a;https://www.bytedance.com/zh/ 豆包官网&#xff1a;https://www.doubao.com/chat/ 更多消息&#xff1a;https://heehel.co…

Redis实战—验证码登录注册

目录 基于Session Controller层 Service层 ServiceImpl层 ​编辑校验登录状态 ThreadLocal 登录拦截器 添加拦截器到Config Controller层实现 基于Redis ServiceImpl 新增刷新拦截器 添加拦截器到Config 基于Session Controller层 /*** 发送手机验证码*/PostMappi…

ROS 手眼标定 realsense435i+ur5e

手眼标定的原理 基坐标系&#xff08;base_tree&#xff09;和相机&#xff08;camera_tree&#xff09;两个坐标系属于不同的tree&#xff0c;通过将标签贴到手上&#xff0c;相机识别出标签的position和orention&#xff0c;并通过easy_handeye标定包得到tool0(机械手)&…

Java面试八股之HashMap和HashTable有什么区别

Java中HashMap和HashTable有什么区别 线程安全性&#xff1a; HashMap&#xff1a;非线程安全。在多线程环境下&#xff0c;如果没有采取适当的同步措施&#xff0c;直接并发访问可能会导致数据不一致、死锁等问题。如果需要在多线程环境中安全地使用HashMap&#xff0c;通常…

中国开源 AI 大模型之光-InternLM2

今天给大家带来 AI 大模型领域的国产之光 - InternLM2&#xff0c;在10B量级开源大模型领域取得了全球 Top 3 的成绩&#xff0c;仅次于 Meta 发布的 Llama-3&#xff0c;在国内则是第一名的存在&#xff01; 简介 InternLM2是由上海人工智能实验室和商汤科技联合研发的一款大型…

【软件测试】需求概念|软件的⽣命周期|开发模型|测试模型

目录 推荐 一、什么是需求 1.1 ⽤⼾需求 1.2 软件需求 二、开发模型 2.1 什么是“模型” 2.2 软件的⽣命周期 2.3 常⻅开发模型 2.3.1 瀑布模型 2.3.2 螺旋模型 2.3.3 增量模型、迭代模型 2.3.4 敏捷模型 2.4 测试模型 2.4.1 V模型 2.4.2 W模型(双V模型&#xff0…

安装ArcGIS失败,提示无效驱动器Error1327.Invalid Drive G错误

安装ArcGIS的时候&#xff0c;出现图中错误该怎么解决呢&#xff1f; Error 1327.Invalid Drive:G:\ 即错误代码&#xff1a;1327。无效驱动器G盘 出现以上问题的原因是 注册表中包含了该硬盘驱动器或网络驱动器的引用 但是在我的电脑中又没有该盘符 一般是已经卸载或者更换…

NSSCTF | [SWPUCTF 2021 新生赛]easyupload2.0

先传一个普通的一句话木马试一试 GIF89a <?php eval($_POST[shell]);?> 可以看到回显&#xff0c;不允许上传php文件。 使用Burpsuite抓包只修改ContentType后发现也不能绕过&#xff0c;说明服务器使用了黑名单后缀限制&#xff0c;那么我们可以使用其他的后缀代替ph…

dubbo复习:(3) 服务超时时间配置

在dubbo admin中 可以进行类似如下配置 configVersion: v2.7 enabled: true configs:- side: consumeraddresses:- 0.0.0.0parameters:timeout: 55这样配置之后&#xff0c;当服务端响应超过55毫秒时&#xff0c;在服务消费者的控制台就会看到超时信息

鸿蒙应用布局ArkUI:【其他常用布局容器和组件】介绍

其他常用布局容器和组件 创建轮播&#xff08;Swiper&#xff09;实现轮播图功能 开发前请熟悉鸿蒙开发指导文档&#xff1a;gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。 栅格布局&#xff08;GridRow/GridCol&#xff09;和Grid布局类似…

TiDB学习1:TiDB体系架构概览

目录 1. TiDB体系结构 2. TiDBsever 3. TiKV 4. PD(Placement Driver) 5. TiFlash 1. TiDB体系结构 水平扩容或者缩容金融级高可用实时 HTAP云原生的分布式数据库兼容MySQ 5.7 协议 2. TiDBsever 处理客户端的连接SQL语句的解析和编译关系型数据与 kv 的转化(insert语句)S…

2024自学网络安全的三个必经阶段(含路线图)_网络安全自学路线

一、为什么选择网络安全&#xff1f; 这几年随着我国《国家网络空间安全战略》《网络安全法》《网络安全等级保护2.0》等一系列政策/法规/标准的持续落地&#xff0c;网络安全行业地位、薪资随之水涨船高。 未来3-5年&#xff0c;是安全行业的黄金发展期&#xff0c;提前踏入…