浙大数据结构慕课课后题(02-线性结构4 Pop Sequence)

题目要求:

给定一个可以保持的堆栈M最多数字。推N1、2、3、...,N并随机弹出。您应该判断给定的数字序列是否是堆栈的可能的弹出序列。例如,如果M是 5 和N是 7,我们可以从堆栈中得到 1、2、3、4、5、6、7,但不能得到 3、2、1、7、5、6、4。

输入规格:

每个输入文件都包含一个测试用例。对于每种情况,第一行包含 3 个数字(均不超过 1000):M(堆栈的最大容量),N(推送序列的长度),以及K(要检查的 pop 序列数)。然后K接下来是几行,每行都包含一个N数字。一行中的所有数字都用空格分隔。

输出规格:

对于每个弹出序列,如果它确实是堆栈的可能弹出序列,则在一行中打印"YES",如果不是,则打印"NO"

示例输入:

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

示例输出:

YES

NO

NO

YES

NO

题解:

思路如注释所示,可通过所有测试点。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int M,N,K;
    cin>>M>>N>>K;
    int stack[M+5] = {0};
    int check[N+5] = {0};
    while(K--){
        int top=-1;
        for(int i=1;i<=N;i++) cin>>check[i];

        for(int i=1,j=1;i<=N;i++){
            stack[++top] = i;  //依次进栈
            if(top==M) break;  //栈已经存储满,仍然没有遇见该弹出的元素
            while(top!=-1&&stack[top] == check[j]){
                top--;
                j++;
            }
        }

        if(top == -1) cout<<"YES\n";
        else cout<<"NO\n";
    }
    return 0;
}
相关推荐
星星火柴9367 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑8 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
闪电麦坤959 小时前
数据结构:迭代方法(Iteration)实现树的遍历
数据结构·二叉树·
Cx330❀9 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散11210 小时前
01数据结构-Prim算法
数据结构·算法·图论
..过云雨10 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
拂晓银砾11 小时前
Java数据结构-栈
java·数据结构
旺小仔.11 小时前
双指针和codetop复习
数据结构·c++·算法
楽码13 小时前
底层技术SwissTable的实现对比
数据结构·后端·算法
瓦特what?14 小时前
关于C++的#include的超超超详细讲解
java·开发语言·数据结构·c++·算法·信息可视化·数据挖掘