Day9 洗盘子 -卡码网C++基础课

题目链接:洗盘子

题目描述

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

盘子堆放区操作说明:

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, 否则或者false
  push(): 进栈操作,将新的元素放入到栈中,新的元素成为栈顶元素。
  pop(): 出栈操作,栈顶元素从栈中离开
  top(): 获取栈顶元素,但是不会移除它
  size(): 获取栈的长度,即栈中元素的数量
posted @ 2025-12-23 17:50  afterday  阅读(2)  评论(0)    收藏  举报