昆玉市网站建设_网站建设公司_后端工程师_seo优化
2025/12/23 17:53:35 网站建设 项目流程

题目链接:洗盘子

题目描述

在餐厅里,洗盘子的工作需要使用到栈这种数据结构。
假设你手里有一个盘子堆放区。现在需要模拟洗盘子的过程,每个盘子都有一个编号。

盘子堆放区操作说明:

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
点击查看代码
#include<iostream>
#include<stack>
using namespace std;
int main(){int n,val,m,x;cin >> n;stack<int> st;while(n--){cin >> val;st.push(val);}cin >> m;while(m--){cin >> x;if(x == 1 && !st.empty()) st.pop();if(x == 2){cin >> val;st.push(val);}}if(st.empty()) cout << "All the dishes have been washed." << endl;else cout << st.top() << endl;return 0;
}
小结

题目思路

通过栈存储编号
再判断操作,1就出栈,2就进栈
要注意出栈要判断是否栈空
最后输出结果,先判断是否栈空。若非输出栈顶元素

知识点

栈 (stack)头文件#include<stack>声明stack<int> st;常用方法empty(): 判断栈是否为空栈,如果为空栈返回true, 否则或者falsepush(): 进栈操作,将新的元素放入到栈中,新的元素成为栈顶元素。pop(): 出栈操作,栈顶元素从栈中离开top(): 获取栈顶元素,但是不会移除它size(): 获取栈的长度,即栈中元素的数量

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询