博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PAT 1051 Pop Sequence[栈][难]
阅读量:5956 次
发布时间:2019-06-19

本文共 2002 字,大约阅读时间需要 6 分钟。

1051 Pop Sequence (25 分)

Given a stack which can keep M numbers at most. Push N numbers in the order of 1, 2, 3, ..., N and pop randomly. You are supposed to tell if a given sequence of numbers is a possible pop sequence of the stack. For example, if M is 5 and N is 7, we can obtain 1, 2, 3, 4, 5, 6, 7 from the stack, but not 3, 2, 1, 7, 5, 6, 4.

Input Specification:

Each input file contains one test case. For each case, the first line contains 3 numbers (all no more than 1000): M(the maximum capacity of the stack), N (the length of push sequence), and K (the number of pop sequences to be checked). Then K lines follow, each contains a pop sequence of N numbers. All the numbers in a line are separated by a space.

Output Specification:

For each pop sequence, print in one line "YES" if it is indeed a possible pop sequence of the stack, or "NO" if not.

Sample Input:

5 7 51 2 3 4 5 6 73 2 1 7 5 6 47 6 5 4 3 2 15 6 4 3 7 2 11 7 6 5 4 3 2

Sample Output:

YESNONOYESNO

 题目大意:给出一个栈最大容量,并且给出最大的N,要求是1....N是这样顺序入栈,输入K个检查的序列,需要判读是不是可能的弹出序列。

 //我看见其实以为自己会,其实是不会的,以前见过这种题的,但是应该当时也没理解吧。

 代码转自:https://www.liuchuo.net/archives/2232

 

#include 
#include
#include
#include
using namespace std;int main() { int m, n, k; scanf("%d %d %d", &m, &n, &k); for(int i = 0; i < k; i++) { bool flag = false; stack
s; vector
v(n + 1); for(int j = 1; j <= n; j++) scanf("%d", &v[j]);//读入要检验的序列。 int current = 1;//指向输入的序列。 for(int j = 1; j <= n; j++) { s.push(j); if(s.size() > m) break; while(!s.empty() && s.top() == v[current]) { s.pop(); current++; } } if(current == n + 1) flag = true; if(flag) printf("YES\n"); else printf("NO\n"); } return 0;}

 

//真的很厉害了,学习了。

1.使用一个current来指向当前的检验序列。

2.如果栈的大小已经大于了容量,那么就退出。

3.还有这个while循环是最关键的,只要top值等于当前current指向的,那么就弹出,并且指向下一个元素,非常厉害了。

//学习了,另一位大佬的代码思路也是相同的。

转载于:https://www.cnblogs.com/BlueBlueSea/p/9703981.html

你可能感兴趣的文章
bootstrap - navbar
查看>>
切图崽的自我修养-[ES6] 编程风格规范
查看>>
[React Native Android 安利系列]样式与布局的书写
查看>>
利用dxflib读写cad文件
查看>>
服务器迁移小记
查看>>
FastDFS存储服务器部署
查看>>
Android — 创建和修改 Fragment 的方法及相关注意事项
查看>>
流程控制: jQ Deferred 与 ES6 Promise 使用新手向入坑!
查看>>
swift基础之_swift调用OC/OC调用swift
查看>>
Devexpress 15.1.8 Breaking Changes
查看>>
推荐JS插件:imagesLoaded,监测图片加载情况并提供相应的事件(加载成功/失败)...
查看>>
Java B2B2C多用户商城 springcloud架构- common-service 项目构建过程(七)
查看>>
杨老师课堂之ArrayList集合常用方法解析
查看>>
ElasticSearch Client详解
查看>>
新零售讲堂之时代下的传统零售业,何去何从?
查看>>
c++读取和写入TXT文件的整理
查看>>
深入动态人脸识别小场景应用,2019年或将迎来爆发期
查看>>
Ionic2 下处理 Android 设备下返回按钮的事件
查看>>
linux安全问答(1)
查看>>
zabbix监控进程的CPU和内存占用量
查看>>