栈实现队列,力扣

题目地址:

232. 用栈实现队列 - 力扣(LeetCode)

难度:简单

今天刷栈实现队列,大家有兴趣可以点上看看题目要求,试着做一下

题目:

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

   实现 MyQueue 类:

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

我们直接看题解吧:

审题目+事例+提示:

·代码实现只能在题目给出的方法进行操作

·这里的输出内容/返回值是调用栈的相关方法时的返回值

解题思路(双栈法):

根据题意,队列的特性是 FIFO(先入先出),而栈的特性是 FILO(先入后出)。

知道两者特性之后,我们需要用两个栈来模拟队列的特性,一个栈为入队栈,一个栈为出对栈。

      ·当出队栈存在内容时,出队栈的栈顶,即为第一个出队的元素。

     ·若出队栈无元素,我们的需求又是出队的话,我们就需要将入队栈的内容逆序导入出队栈,然后弹出栈顶即可。

代码实现:

class MyQueue {Deque<Integer> inStack;   //创建Deque双端队列充当入队栈与出队栈Deque<Integer> outStack;  //注意,Deque是一个接口public MyQueue() {inStack = new LinkedList<Integer>();  //在构造方法中创建双向链表集合对象outStack = new LinkedList<Integer>(); //利用Deque接口其中的一个实现类}public void push(int x) {          //对入队栈进行压栈操作inStack.push(x);}public int pop() {              //对入队栈进行弹出栈操作if (outStack.isEmpty()) {  //判出队栈是否为空,空则调用in2out()方法in2out();}return outStack.pop();}public int peek() {if (outStack.isEmpty()) {  //判出队栈是否为空,空则调用in2out()方法in2out();}return outStack.peek();}public boolean empty() {  //返回判断值(入队栈与出队栈是否均为空)return inStack.isEmpty() && outStack.isEmpty();}private void in2out() {while (!inStack.isEmpty()) {          //若入队栈不为空则进行循环outStack.push(inStack.pop());   //将入队栈内容导入出队栈}}
}
。
代码补充说明: 

注意哈:

Java堆栈Stack类已经过时,Java官方推荐使用Deque替代Stack使用。

Deque是一个双端队列接口,继承自Queue接口。

    · Deque的实现类是LinkedList、ArrayDeque、LinkedBlockingDeque,其中LinkedList是最常用的。

    ·Deque堆栈操作方法:push()、pop()、peek()等。 

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

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

相关文章

xilinx系列FPGA基于VIVADO的pin delay列表生成说明

目录 1 概述2 示例平台3 操作说明4 注意事项 xilinx系列FPGA基于VIVADO的pin delay列表生成说明 1 概述 本文用于讲诉xilinx系列FPGA基于VIVADO的pin delay列表生成说明&#xff0c;以及一些注意事项&#xff0c;为FPGA设计人员探明道路。 Pin delay 即FPGA内部die到pin的延时…

ios 长传发布审核+safari浏览器,直接安装ipa文件

蒲公英二维码方法 个人开发者账号发布证书AD-hoc 描述文件蒲公英上传链接通过苹果safari 浏览器下载IPA包 浏览器下载方法 前置条件 1.下载 ipa 包的设备的 uuid 已加入 苹果测试设备列表如何添加到测试列表 2.web 服务, 文件服务. 3.需要AD-hoc 描述文件 添加链接描述 1.创…

java实验:数据库应用(idea+mysql+php)

设计用户注册和登录界面&#xff0c;实现用户注册和登录操作。 设计用户注册/登录界面;使用工具在MySQL中创建user表&#xff0c;包括学号、姓名、密码、专业、班级&#xff1b;实现注册操作&#xff1a;在user表中插入一条新纪录&#xff0c;但学号不能重复&#xff1b;实现登…

边缘数据中心和5G的融合彻底改变数据传输和物联网

伴随着数字化时代的飞速发展&#xff0c;边缘数据中心和5G技术的联袂崛起&#xff0c;正深刻塑造着人们对数据的创造、传输和处理方式。据Gartner公司的预测&#xff0c;到2025年&#xff0c;企业数据的三分之二将在边缘计算设施中涌现&#xff0c;而非传统的集中式数据中心。这…

如何在 Ubuntu 22.04中安装 Docker Compose

1 安装 pip # 下载get-pip.py脚本 wget https://bootstrap.pypa.io/pip/3.10/get-pip.py 或者 # 下载最新版本 curl https://bootstrap.pypa.io/get-pip.py --output get-pip.py# 为 Python 3 安装 pip sudo python3 get-pip.py2 安装 Pip 后&#xff0c;运行以下命令安装 Doc…

JavaScript 数据结构

JavaScript 数据结构 目录 JavaScript 数据结构 一、标识符 二、关键字 三、常量 四、变量 每一种计算机编程语言都有自己的数据结构&#xff0c;JavaScript脚本语言的数据结构包括&#xff1a;标识符、常量、变量、保留字等。 一、标识符 标识符&#xff0c;说白了&…

macos pycharm调试airflow代码

项目目录&#xff1a;本案例基于pycharm项目虚拟环境 1.进入项目虚拟环境目录 yololibogon bin % pwd /Users/yololi/PycharmProjects/pythonProjecttest/venv/bin 2.安装airflow ./python3.8 -m pip install apache-airflow2.2.5 -i https://pypi.tuna.tsinghua.edu.cn/sim…

Vmware安装Centos7

CentOs7镜像文件下载 centos7 镜像文件下载-CSDN博客 配置虚拟机 打开Vmware&#xff0c;点击新建虚拟机 典型安装与自定义安装 典型安装&#xff1a;VMware会将主流的配置应用在虚拟机的操作系统上&#xff0c;对于新手来很友好。 自定义安装&#xff1a;自定义安装可以针…

柱状展示当中 ,如何给每个位置加多个项的办法

<!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>双柱修改</title> <script src"https://cdn.staticfile.org/Chart.js/3.9.1/chart.js"></script> </head> <body><canvas i…

Linux部署elasticsearch集群

文章目录 一、集群规划二、安装前准备(所有节点操作)创建数据目录修改系统配置文件/etc/sysctl.conf创建用户组设置limits.conf 三、初始化配置(在节点1上操作)下载安装包解压安装包修改jvm.options文件下配置的所占内存修改集群配置文件elasticsearch.yml将安装包传到另外两个…

「Verilog学习笔记」整数倍数据位宽转换8to16

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 根据时序图&#xff0c;数据是在第二个数据到来之后输出&#xff0c;当仅有一个数据到来时&#xff0c;不产生输出&#xff0c;所以内部需要一个指示信号valid_cnt&#xf…

ZooKeeper 如何保证数据一致性?

在分布式场景中&#xff0c;ZooKeeper 的应用非常广泛&#xff0c;比如数据发布和订阅、命名服务、配置中心、注册中心、分布式锁等。 ZooKeeper 提供了一个类似于 Linux 文件系统的数据模型&#xff0c;和基于 Watcher 机制的分布式事件通知&#xff0c;这些特性都依赖 ZooKee…