当前位置: 首页 > news >正文

142.栈和队列:用栈实现队列(力扣)

题目描述

代码解决

class MyQueue {
public:stack<int> stIn;  // 输入栈,用于push操作stack<int> stOut; // 输出栈,用于pop和peek操作MyQueue() {}void push(int x) {stIn.push(x); // 将元素压入输入栈}int pop() {// 如果输出栈为空,则将输入栈的元素转移到输出栈if(stOut.empty()){while(!stIn.empty()){stOut.push(stIn.top()); // 将输入栈的顶部元素压入输出栈stIn.pop(); // 弹出输入栈的顶部元素}}int result=stOut.top(); // 取输出栈的顶部元素stOut.pop(); // 弹出输出栈的顶部元素return result; // 返回弹出的元素}int peek() {// 如果输出栈为空,则将输入栈的元素转移到输出栈if(stOut.empty()){while(!stIn.empty()){stOut.push(stIn.top()); // 将输入栈的顶部元素压入输出栈stIn.pop(); // 弹出输入栈的顶部元素}}return stOut.top(); // 返回输出栈的顶部元素(不弹出)}bool empty() {return stIn.empty() && stOut.empty(); // 判断输入栈和输出栈是否都为空}
};
  1. MyQueue有两个私有成员变量:stInstOut,分别用于存储入队和出队的元素。

  2. 构造函数MyQueue()没有参数,它只是初始化了两个栈。

  3. push(int x)方法用于将元素x入队。它将元素x压入stIn栈。

  4. pop()方法用于出队,并返回队首元素。如果stOut栈为空,说明队列中没有元素可以出队,因此需要将stIn栈中的元素全部移到stOut栈中。这可以通过一个循环来实现,每次将stIn栈的顶部元素移到stOut栈中,然后出栈。最后,返回stOut栈的顶部元素。

  5. peek()方法用于查看队首元素,但不将其出队。它与pop()方法类似,但是不将队首元素出队,而是返回它。

  6. empty()方法用于判断队列是否为空。如果stIn栈和stOut栈都为空,则返回true;否则返回false

http://www.lryc.cn/news/358095.html

相关文章:

  • 乡村振兴的乡村产业创新发展:培育乡村新兴产业,打造乡村产业新名片,促进乡村经济多元化发展
  • 数据库|基于T-SQL创建数据库
  • 智能家居ZigBee网关选型定制指南:主控,操作系统,天线设计,助力IoT开发者
  • QT截图程序,可多屏幕截图二,增加调整截图区域功能
  • 开源浪潮与闭源堡垒:大模型未来的双重奏
  • postman教程-6-发送delete请求
  • java小技能: 数字和字母组合的验证码图片(生成验证码字符并加上噪点,干扰线)
  • 网络故障与排除
  • Cocos Creator 编辑器的数据绑定详解
  • 解决Selenium NameError: name ‘By’ is not defined
  • 创建特定结构的二维数组:技巧与示例
  • React Native 之 BackHandler (二十)
  • 一篇文章讲透排序算法之快速排序
  • kubernetes-PV与PVC、存储卷
  • 643. 子数组最大平均数 I
  • Node性能如何进行监控以及优化?
  • ToList()和ToArray()的区别
  • 11.RedHat认证-Linux文件系统(中)
  • windows系统电脑外插键盘驱动出现感叹号或者显示未知设备,键盘无法输入的解决办法
  • 【开源项目】Excel数据表自动生成工具v1.0版
  • Docker-一文详解容器通信的基础网络模式及衍生的自定义网络模式
  • Convolutional Occupancy Networks【ECCV】
  • Android Studio 问题集锦
  • J.搬砖【蓝桥杯】/01背包+贪心
  • 拥塞控制的微观行为与力学解释
  • 每日一读: 硬件网卡tx支持哪些功能特性offload(ixgbe驱动为例)
  • MyBatis的坑(动态SQL会把0和空串比较相等为true)
  • Springboot事务控制中A方法调用B方法@Transactional生效与不生效情况实战总结
  • python -【三】循环语句
  • 类的内存对齐位段位图布隆过滤器哈希切割一致性哈希