JAVA 栈的实现

洗盘子

时间限制:1.000S  空间限制:128MB

题目描述

在餐厅里,洗盘子的工作需要使用到栈这种数据结构。

假设你手里有一个盘子堆放区。现在需要模拟洗盘子的过程,每个盘子都有一个编号。 

盘子堆放区操作说明: 

1. 当操作为 1 时,表示从盘子堆放区拿走顶部的盘子清洗。
2. 当操作为 2 时,表示有未洗的盘子放入盘子堆放区。 

在一系列操作之后,你需要回答:下一个清洗的盘子编号?

输入描述

第一行有一个整数 n,代表初始盘子堆放区中盘子的数量为 n。 

第二行有 n 个整数,代表了盘子的编号,同时整数之间的顺序也代表了未洗盘子加入盘子堆放区的顺序。 

第三行为一个整数 m,代表接下来将会有 m 次操作。 

接下来一共有 m 行,代表共有 m 次操作。 

如果是操作 1,那么该行只会有一个数字 1,代表有一个盘子被拿走清洗。 

如果是操作 2,那么该行有两个数字,第一个数字 2 表示有未洗的盘子加入,第二个数字代表未洗的盘子编号。

输出描述

输出共一行,为下一个该清洗的盘子编号。 如果没有下一个该清洗的盘子,那么请输出 “All the dishes have been washed.”

输入示例
5
1001 1002 1003 1004 1005
3
1
1
2 1006
输出示例
1006

 

栈的操作实际上和洗盘子的过程是类似的,洗盘子的过程中,会拿出待清洗那一摞盘子的最顶端的那个盘子,清洗之后将其放在已清洗区域,这对于待清洗盘子来说是出栈,对于已清洗区域来说,是入栈(进栈),具体的过程可以看下面的图示:

栈这种结构只能在一侧(栈顶那一侧)进行插入和删除操作,而且是后进先出LIFO(后进入栈的元素离栈顶比较近,先出来),允许进行插入和删除的那一端是栈顶,与之对应的另一端是栈底, 如果一个栈不包含任何元素,这个栈被称为空栈

在计算机领域,栈的应用也十分广泛,比如浏览器的历史回退和编写文档时的“撤销”操作。

栈的操作

在Java中,你可以使用java.util.Stack类来实现栈(Stack)这种数据结构。

import java.util.Stack; // 导入 Java 标准库的 Stack

然后就可以通过new操作来创建一个栈对象并进行操作了。

Stack<Integer> stack = new Stack<>();  // 创建一个栈对象

栈的常用操作主要有以下几种:

  • isEmpty(): 判断栈是否为空栈,如果为空栈返回true, 否则或者false
  • push(): 进栈操作,将新的元素放入到栈中,新的元素成为栈顶元素。
  • pop(): 出栈操作,栈顶元素从栈中离开, 并且返回栈顶元素。
  • peek(): 获取栈顶元素,但是不会移除它。
  • size(): 获取栈的长度,即栈中元素的数量。
stack.push(1);
stack.push(10);
stack.push(100); // 往栈中添加元素,现在栈底元素是1,栈顶元素是100stack.pop(); // 移除栈顶元素100,新的栈顶元素是10int topNumber = stack.peek(); // 获取栈顶元素10,但是不会移除boolean isEmpty = stack.isEmpty(); // 如果栈为空,返回true;否则返回falseint stackSize = stack.size(); // 获取栈的长度(元素数量)

 JAVA代码实现:

import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();Stack<Integer> sta = new Stack<>();// 将输入的元素依次入栈for (int i = 0; i < n; i++) {int x = sc.nextInt();sta.push(x);}int m = sc.nextInt();int op;for (int i = 0; i < m; i++) {op = sc.nextInt();if (op == 1) {// 如果栈不为空,则弹出栈顶元素if (!sta.empty())sta.pop();elsecontinue;}if (op == 2) {// 将输入的元素入栈sta.push(sc.nextInt());}}if (!sta.isEmpty()) {// 输出栈顶元素System.out.println(sta.peek());} else {System.out.println("All the dishes have been washed.");}}
}

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

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

相关文章

在 Windows 10 上使用 Visual Studio 2022 进行 C++ 桌面开发

工具下载链接&#xff1a;https://pan.quark.cn/s/c70b23901ccb 环境介绍 在今天的快速发展的软件开发行业中&#xff0c;选择合适的开发环境是非常关键的一步。对于C开发人员来说&#xff0c;Visual Studio 2022&#xff08;VS2022&#xff09;是一个强大的集成开发环境&…

C#中检查空值的最佳实践

C#中检查空值的最佳实践 在C#编程中&#xff0c;处理空值是一项基础且重要的任务。正确地检查变量是否为null可以帮助我们避免NullReferenceException&#xff0c;这是C#最常见的运行时错误之一。本文将探讨为什么使用is关键字进行空值检查是一种优于使用的做法。 操作符&…

YOLOv7改进:下采样系列 | 一种新颖的基于 Haar 小波的下采样HWD,有效涨点系列

💡💡💡本文独家改进:HWD的核心思想是应用Haar小波变换来降低特征图的空间分辨率,同时保留尽可能多的信息,与传统的下采样方法相比,有效降低信息不确定性。 💡💡💡使用方法:代替原始网络的conv,下采样过程中尽可能包括更多信息,从而提升检测精度。 收录 YO…

C程序设计(第5版)谭浩强习题解答 第7章 用函数实现模块化程序设计

C程序设计(第5版)谭浩强习题解答 第7章 用函数实现模块化程序设计 1.写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这两个函数,并输出结果。两个整数由键盘输人。 //7.1.1 #include <stdio.h> int main() {int hcf(int, int);int lcd(int, int, in…

聊聊DoIP吧(一)

DoIP是啥? DoIP代表"Diagnostic over Internet Protocol",即互联网诊断协议。它是一种用于在车辆诊断中进行通信的网络协议。DoIP的目标是在现代汽车中实现高效的诊断和通信。通过使用互联网协议(IP)作为通信基础,DoIP使得诊断信息能够通过网络进行传输,从而提…

uniCloud -- uniIdRouter自动路由

目录 自动路由 云对象响应触发needLogin 获取当前用户信息getCurrentUserInfo 实战应用 个人中心页面 pages.json配置 uni-id自动路由 uni_modules\uni-id-pages/common 登录页面store修改 自动路由 支持的HBuilderX版本 uni-appuni-app x3.5.03.99 uniIdRouter 是一…

前端学习笔记 | 响应式网页+Boostrap

一、响应式网页 一套代码适应多端 1、媒体查询media(条件){css} max-width 小于等于max-width生效min-width 【案例】左侧隐藏 因为CSS的层叠性&#xff0c;书写顺序&#xff1a;max-width从大到小&#xff1b;min-width从小到大。 【媒体查询完整写法】 在html中link用于不同…

前端小案例——导航回顶部(HTML+CSS+JS, 附源码)

一、前言 实现功能&#xff1a; 这个案例实现了页面滚动到一定位置时显示"回到顶部"按钮&#xff0c;并且点击按钮能够平滑滚动回页面顶部的功能。 实现逻辑&#xff1a; 页面结构&#xff1a;通过HTML标签定义了页面的基本结构。页面主要由多个div.content组成&am…

Springboot整合Websocket实现ws和wss连接

1. 引入pom依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId><version>2.7.10</version> </dependency>2. 新建websocket配置文件 import org.springf…

Linux笔记之bash和expect脚本中的$和$argv参数匹配

Linux笔记之bash和expect脚本中的 和 和 和argv参数匹配 —— 杭州 2024-02-03 code review! 文章目录 Linux笔记之bash和expect脚本中的 和 和 和argv参数匹配1.bash脚本2.expect脚本 1.bash脚本 在Linux的bash脚本中&#xff0c;参数和脚本文件名的变量使用方式与你提供的稍…

springboot(ssm银行柜台管理系统 银行账户管理系统Java系统

springboot(ssm银行柜台管理系统 银行账户管理系统Java系统 开发语言&#xff1a;Java 框架&#xff1a;springboot&#xff08;可改ssm&#xff09; vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.7&a…

曲线拟合、多项式拟合、最小二乘法

最近在做自车轨迹预测的工作&#xff0c;遇到 曲线拟合、多项式拟合、最小二乘法这些概念有点不清晰&#xff0c; 做一些概念区别的总结&#xff1a; 曲线拟合用于查找一系列数据点的“最佳拟合”线或曲线。 大多数情况下&#xff0c;曲线拟合将产生一个函数&#xff0c;可用于…

Java volatile关键字是否能保证线程安全

是的&#xff0c;Java中的volatile关键字可以用于保证线程安全。 volatile关键字的作用是确保多线程环境下的变量可见性。当一个共享变量被volatile修饰后&#xff0c;它会保证修改的值会立即被更新到主内存&#xff0c;当有其他线程需要读取这个变量时&#xff0c;它会去主内…

数论基础知识(整除,质数,合数,质因数,取模,同余)

整除 ​ 整除的定义&#xff1a;设a,b∈Z&#xff0c;a≠0。如果q∈Z&#xff0c;使得baq&#xff0c;那么就说b可被a整除&#xff0c;记作a&#xff5c;b。 ​ 若整数a除以非零整数b&#xff0c;商为整数&#xff0c;且余数为零&#xff0c; 我们就说a能被b整除&#xff08;…

蓝桥杯省赛无忧 课件70 第九次学长直播带练配套课件

01 混境之地5 02 最快洗车时间 03 安全序列 04 可构造的序列总数 05 拍照 06 破损的楼梯

Android Display显示框架整体流程

一.Android Display显示框架整体流程图

大数据环境搭建(一)-Hadoop

1. 服务器环境准备 Linux镜像: centos7.9JDK: jdk1.8.0_212Hadoop: apache-hadoop-3.3.4 创建虚拟Linux服务器 配置虚拟机&#xff0c;每台主机名与ip如下 主机名ipbd-centos01192.168.159.101bd-centos02192.168.159.102bd-centos03192.168.159.103 修改网络配置文件&…

webassembly003 ggml.js试用(暂记)

git clone https://github.com/rahuldshetty/ggml.js-examples.gitpython -m http.sever启动服务器 虽然推理运行了一会&#xff0c;但是风扇没有任何响声。 Using Examples 感觉这个有点笨拙 Instruction: {dow you know about Uncaught invalid worker function to call: …

【数据结构】双向链表 超详细 (含:何时用一级指针或二级指针;指针域的指针是否要释放)

目录 一、简介 二. 双链表的实现 1.准备工作及其注意事项 1.1 先创建三个文件 1.2 注意事项&#xff1a;帮助高效记忆 1.3 关于什么时候 用 一级指针接收&#xff0c;什么时候用 二级指针接收&#xff1f; 1.4 释放节点时&#xff0c;要将节点地址 置为NULL&#xff0…

某赛通电子文档安全管理系统 UploadFileToCatalog SQL注入漏洞复现

0x01 产品简介 某赛通电子文档安全管理系统(简称:CDG)是一款电子文档安全加密软件,该系统利用驱动层透明加密技术,通过对电子文档的加密保护,防止内部员工泄密和外部人员非法窃取企业核心重要数据资产,对电子文档进行全生命周期防护,系统具有透明加密、主动加密、智能…