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

[Easy] leetcode-225/232 栈和队列的相互实现

一、用栈实现队列

1、题目

        仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty): 

实现 MyQueue 类:void push(int x) 将元素 x 推到队列的末尾
int pop() 从队列的开头移除并返回元素
int peek() 返回队列开头的元素
boolean empty() 如果队列为空,返回 true ;否则,返回 false

2、解答

class MyQueue {
private://双栈stack<int> inStack, outStack;void in2out() {while (!inStack.empty()) {outStack.push(inStack.top());inStack.pop();}}
public:MyQueue() {}void push(int x) {inStack.push(x);}int pop() {if (outStack.empty()) {in2out();}int x = outStack.top();outStack.pop();return x;}int peek() {if (outStack.empty()) {in2out();}return outStack.top();}bool empty() {return outStack.empty() && inStack.empty();}
};

二、用队列实现栈

1、题目

        仅使用两个队列实现一个后入先出(LIFO)的栈,并支持普通栈的全部四种操作(push、top、pop 和 empty)。

实现 MyStack 类:void push(int x) 将元素 x 压入栈顶。
int pop() 移除并返回栈顶元素。
int top() 返回栈顶元素。
boolean empty() 如果栈是空的,返回 true ;否则,返回 false 。

2、解答

class MyStack {
private:queue<int> queue1;queue<int> queue2;public:MyStack() {}//在push时就放好了顺序,后来的数据放在队列1的前端,pop时候直接取front即可void push(int x) {queue2.push(x);while(!queue1.empty()) {queue2.push(queue1.front());queue1.pop();}swap(queue1, queue2);}int pop() {int x = queue1.front();queue1.pop();return x;}int top() {int x = queue1.front();return x;}bool empty() {return queue1.empty() && queue2.empty();}
};

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

相关文章:

  • Springboot+Vue项目-基于Java+MySQL的个人云盘管理系统(附源码+演示视频+LW)
  • Leetcode 116:填充每一个节点的下一个右侧节点指针
  • AI智能分析赋能EasyCVR视频汇聚平台,为安全生产监管提供保障
  • Java设计模式 _结构型模式_外观模式
  • 数据结构之----栈与队列
  • 如何在windows server下安装mysql5.7数据库,并使用Navicat Premium 15可视化工具新建数据库并读取数据库信息。
  • Calendar 366 II for Mac v2.15.5激活版:智能日历管理软件
  • react引入阿里矢量库图标
  • 部署Gerapy
  • Github Benefits 学生认证/学生包 新版申请指南
  • 基于单片机的宠物智能投喂系统研究
  • Linux-笔记 常用命令
  • MySQL中,关于日期类型的那些事儿,你知道哪些?
  • 【Chrome实用命令笔记】
  • 【数据库】数据库事务原理
  • LeetCode 106.从中序与后序遍历序列构造二叉树
  • Python中的compile()函数,动态编译代码的艺术
  • 【考研数学】汤家凤“免单“数学题被吐槽‘太难’,老汤回应「怎么还有脸笑」,网友:这些题有毒!
  • 在另外一个页面,让另外一个页面弹框显示操作(调佣公共的弹框)
  • 如何利用IPIDEA代理IP优化数据采集效率?
  • Rpcx (一):详解【介绍、基础示例 demo】
  • 对数据进行标准化和归一化
  • 【从零开始学架构 架构基础】二 架构设计的复杂度来源:高性能复杂度来源
  • OpenHarmony 实战开发——3.1 Release + Linux 原厂内核Launcher起不来问题分析报告
  • 小猫咪邮件在线发送系统源码,支持添加附件
  • Django REST framework(DRF)是什么?
  • 用hMailServer+roundcubemail+宝塔安装配置一个自己的邮箱服务
  • ctfshow 框架复现
  • 【Linux-IMX6ULL-DDR3简介测试-RGBLCD控制原理】
  • 贪心算法-----柠檬水找零