1051. Pop Sequence
原题连接:https://www.patest.cn/contests/pat-a-practise/1051
题目:
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 5
1 2 3 4 5 6 7
3 2 1 7 5 6 4
7 6 5 4 3 2 1
5 6 4 3 7 2 1
1 7 6 5 4 3 2
Sample Output:
YES
NO
NO
YES
NO
这道题我参阅了 http://blog.csdn.net/whzyb1991/article/details/46663867 这篇博文的思路,稍有改动,并且我是用链式存储堆栈,而博文的作者是用顺序存储的方式,读者可以对比两种
方式的优缺点。
这道题并不是有多复杂,关键在于想出it is not a possible pop sequence of the stack的条件!我是苦于没有思路,才参阅了博主的文章。共勉!
我的代码:
#include<stdio.h>
#include<stdlib.h>
#include<stdbool.h>
#define Max 1000
typedef struct SNode{
int Data;
struct SNode *Next;
}Stack; Stack *CreateStack()
{
Stack *Ptrs=(Stack*)malloc(sizeof(struct SNode));
Ptrs->Next=NULL;
return Ptrs;
} bool IsEmpty(Stack *Ptrs)
{
return(Ptrs->Next==NULL);
} void Push(Stack *Ptrs,int X)
{
Stack *S;
S=(Stack *)malloc(sizeof(struct SNode));
S->Data=X;
S->Next=Ptrs->Next;
Ptrs->Next=S;
} void Pop(Stack *Ptrs)
{
if(IsEmpty(Ptrs)) return;
Stack *FirstCell;
FirstCell=Ptrs->Next;
Ptrs->Next=FirstCell->Next;
free(FirstCell);
}
/* 计算堆栈的长度 */
int Length(Stack *Ptrs)
{
Stack *p;
p=Ptrs->Next;
int cnt =;
while(p)
{
cnt++;
p=p->Next;
}
return cnt;
}
/* 检验每一line是否符合要求 */
int check_stack(int *v,int N,int M)
{
int i=;
int num=;
Stack*ps;
ps=CreateStack();
Push(ps,); //先给栈中压入一个元素0
while(i<N) //审核每个已给元素
{ /* 核心 */ //入栈条件;当前栈顶元素小于已给数字,并且(前提条件)栈内元素的总容量小于栈的容量
while(ps->Next->Data<v[i] && Length(ps)<M+)
Push(ps,num++); //压入数num后,由于"the order is 1,2,……N。故下一个压入的数必为num+1;
if (ps->Next->Data==v[i])
{
Pop(ps); //栈顶元素出栈
i++; //之后的栈顶元素和下一个已给元素继续比较
}
else
{
free(ps);
return ;} //False!
}
free(ps);
return ; }
int main()
{
int M,N,K;
scanf("%d %d %d",&M,&N,&K); int *v=(int *)malloc(sizeof(int)*N);
int i,j;
for(i=;i<K;i++)
{
for (j=;j<N;j++)
{
scanf("%d",v+j);
}
if(check_stack(v,N,M))printf("YES\n");
else printf("NO\n");
}
free(v);
return ; }
1051. Pop Sequence的更多相关文章
- PAT 解题报告 1051. Pop Sequence (25)
1051. Pop Sequence (25) Given a stack which can keep M numbers at most. Push N numbers in the order ...
- PAT 1051 Pop Sequence[栈][难]
1051 Pop Sequence (25 分) Given a stack which can keep M numbers at most. Push N numbers in the order ...
- PAT 甲级 1051 Pop Sequence (25 分)(模拟栈,较简单)
1051 Pop Sequence (25 分) Given a stack which can keep M numbers at most. Push N numbers in the ord ...
- PAT 1051 Pop Sequence (25 分)
返回 1051 Pop Sequence (25 分) Given a stack which can keep M numbers at most. Push N numbers in the ...
- 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 ...
- PAT 甲级 1051 Pop Sequence
https://pintia.cn/problem-sets/994805342720868352/problems/994805427332562944 Given a stack which ca ...
- 【PAT】1051 Pop Sequence (25)(25 分)
Given a stack which can keep M numbers at most. Push N numbers in the order of 1, 2, 3, ..., N and p ...
- PAT Advanced 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 ...
- 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 p ...
随机推荐
- 序列化多个form表单内容同时提交
一.首先将表单主体序列化为json对象. 方法: //将表单序列化为json,这里加了个jQuery的扩展方法 $.fn.serializeJson = function () { var resul ...
- css的relative和position探究
在CSS中,Position 属性经常会用到,主要是绝对定位和相对定位,简单的使用都没有问题,尤其嵌套起来,就会有些混乱,今记录总结一下,防止久而忘之. CSS position 属性值: absol ...
- go:结构体的可访问性
1.要使某个符号对其他包( package)可见(即可以访问),需要将该符号定义为以大写字母开头------摘自go相关书籍2.go只限制包内外的可访问性,而不限制同包内不同文件的可访问性 本文讨论结 ...
- 关于Response.Redirect 端口不一致的跳转
如果内网和外网的端口号设置的不相同,那在使用Response.Redirect跳转的时候会无法成功.需要做以下设置: <system.web> <httpRuntime useFul ...
- Flex中的initialize,creationComplete和applicationComp
转自:http://blog.csdn.net/sjz168/article/details/7244374 1.Application标签中有三个事件initialize,creationCompl ...
- PE读写
// 仿PE文件.cpp : Defines the entry point for the console application.// #include "stdafx.h"# ...
- 常用Javascript语法
1.document.write(""); 输出语句 2.JS中的注释为// 3.传统的HTML文档顺序是:document->html->(head,body) 4. ...
- 扩展方法 1 简单的string扩展方法
这里是关于 String的简单扩展方法 (静态类 静态方法 this 类型 这里是string) static class Program { static void Main(string[] ar ...
- jshint 一些选项(转载)
内容来自: http://www.cnblogs.com/qianduanjingying/p/6185793.html 一些变量的作用: http://www.cnblogs.com/CloudMu ...
- WebGL入门教程(四)-webgl颜色
前面文章: WebGL入门教程(一)-初识webgl WebGL入门教程(二)-webgl绘制三角形 WebGL入门教程(三)-webgl动画 颜色效果图: 操作步骤: 1.创建HTML5 canva ...