【洛谷 P4387】【深基15.习9】验证栈序列 题解(模拟+栈+队列)

2024-02-12 21:44

本文主要是介绍【洛谷 P4387】【深基15.习9】验证栈序列 题解(模拟+栈+队列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【深基15.习9】验证栈序列

题目描述

给出两个序列 pushed 和 poped 两个序列,其取值从 1 到 n ( n ≤ 100000 ) n(n\le100000) n(n100000)。已知入栈序列是 pushed,如果出栈序列有可能是 poped,则输出 Yes,否则输出 No。为了防止骗分,每个测试点有多组数据。

输入格式

第一行一个整数 q q q,询问次数。

接下来 q q q 个询问,对于每个询问:

第一行一个整数 n n n 表示序列长度;

第二行 n n n 个整数表示入栈序列;

第三行 n n n 个整数表示出栈序列;

输出格式

对于每个询问输出答案。

样例 #1

样例输入 #1

2
5
1 2 3 4 5
5 4 3 2 1
4
1 2 3 4
2 4 1 3

样例输出 #1

Yes
No

思路

首先定义一个栈s1和两个队列pupo。其中,s1用于模拟栈操作,pu用于存储输入的原始序列,po用于存储目标序列。

在主函数main中,首先输入一个数q,表示接下来有q组数据需要处理。对于每一组数据,首先输入一个数n,表示序列的长度。然后清空栈和两个队列,以便处理新的一组数据。

接下来,输入n个数,这些数构成了原始序列,按照输入的顺序依次添加到队列pu中。再输入n个数,这些数构成了目标序列,按照输入的顺序依次添加到队列po中。

然后,开始模拟栈操作。对于原始序列中的每一个元素,都执行入栈操作,然后检查栈顶元素是否等于目标序列的第一个元素,如果相等,就同时执行出栈操作和删除目标序列的第一个元素。这个过程一直持续到原始序列中的所有元素都被处理完。

最后,如果栈为空,表示原始序列可以通过一系列的入栈和出栈操作得到目标序列,输出"Yes";否则,表示不能得到目标序列,输出"No"。


AC代码

#include <algorithm>
#include <iostream>
#include <queue>
#include <stack>
#define AUTHOR "HEX9CF"
using namespace std;stack<int> s1;
queue<int> pu, po;int main() {int q;cin >> q;while (q--) {int n;cin >> n;while (s1.size()) {s1.pop();}while (pu.size()) {pu.pop();}while (po.size()) {po.pop();}for (int i = 1; i <= n; i++) {int t;cin >> t;pu.push(t);}for (int i = 1; i <= n; i++) {int t;cin >> t;po.push(t);}for (int i = 1; i <= n; i++) {s1.push(pu.front());pu.pop();while (s1.size() && s1.top() == po.front()) {po.pop();s1.pop();}}if (s1.empty()) {cout << "Yes" << endl;} else {cout << "No" << endl;}}return 0;
}

这篇关于【洛谷 P4387】【深基15.习9】验证栈序列 题解(模拟+栈+队列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/703683

相关文章

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

hdu1180(广搜+优先队列)

此题要求最少到达目标点T的最短时间,所以我选择了广度优先搜索,并且要用到优先队列。 另外此题注意点较多,比如说可以在某个点停留,我wa了好多两次,就是因为忽略了这一点,然后参考了大神的思想,然后经过反复修改才AC的 这是我的代码 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<