判断序列是否为正确的出栈序列
创始人
2024-02-19 04:25:27
0

问题引入 

【问题描述】

给出一个堆栈的输入序列,试判断一个输出序列是否能够由这个堆栈输出。如果能,返回总的出栈次数,如果不能,输出0。

序列的输入及输出都是从左往右。(输入输出序列皆为整数且没有重复的数字,如果一个数字在输入序列中没有出现,那么其在输出序列中也不会出现)

【输入形式】

第一行为输入序列的长度,其后依次为输入序列的数字;

第二行为输出序列的数字。

输入数据以空格隔开。

【输出形式】

如果是一个正确的出栈序列,则输出总的出栈次数, 否则返回0

【样例输入1】

5 1 2 3 4 5

4 5 3 2 1

【样例输出1】

5

【样例说明1】可以按以下顺序执行:

push(1), push(2), push(3), push(4), pop() -> 4, push(5), pop() -> 5, pop() -> 3, pop() -> 2, pop() -> 1

通过5次pop操作可以得到输出序列,因此返回5

【样例输入2】

5 1 2 3 4 5

4 3 5 1 2

【样例输出2】0

【样例说明2】1不能在2之前输出,因此返回0

【评分标准】

填充主函数代码,调用堆栈基本操作完成输出序列判断。 

程序设计 

#include
#include
#include
#define ERROR 0
#define OK 1
#define INIT_SIZE 100
#define INCREMENT 20

typedef int ElemType;
typedef struct SqStack{
    ElemType *base,*top;
    int stacksize;
}SqStack;
int InitStack(SqStack *S)
{
   S->base=(ElemType *)malloc(INIT_SIZE*sizeof(ElemType));
       if(!S->base) return ERROR;
       S->top=S->base;
       S->stacksize=INIT_SIZE;
       return OK;
}
int Empty(SqStack *S)
{
    if(S->top==S->base){
            return OK; 
        }else{
            return ERROR;
        } 
}
int Push(SqStack *S,ElemType e)
{
   if(S->top-S->base>=S->stacksize){
           S->base=(ElemType*)realloc(S->base,(S->stacksize+INCREMENT)*sizeof(ElemType));
           if(!S->base) return ERROR;
           S->top=S->base+S->stacksize;
           S->stacksize+=INCREMENT;
       }
       *S->top++=e;//*s->top=e;s->top++;
       return OK;
}
int Pop(SqStack *S,ElemType *e)
{
    if(S->top==S->base) return ERROR;
        *e=*--S->top;//s->top--;*e=*s->top;
        return OK;
}
int GetTop(SqStack *S,ElemType *e)
{
   S->top--;
       *e=*S->top;
       S->top++;
       return OK;
}


int main()
{
    SqStack s;
    ElemType e;
    InitStack(&s);
    int in[100]; 
    int out[100];   
    int n=0,m=0;
    int rec = 0;
    scanf("%d", &n);
    for(int i=0;i
        scanf("%d", &in[i]);
    }
    for(;scanf("%d", &out[m])==1;m++);
    int aa=0,bb=0;
    while(bb
        if(Empty(&s)){
            Push(&s, in[aa++]);
            continue;
        }
        GetTop(&s, &e);
        if(e!=out[bb]){
            Push(&s, in[aa++]);
        }else{
            Pop(&s,&e);
            bb++;
            rec++;
        }
    }
    if(bb==m){
        printf("%d",rec);
    }else{
        printf("0");
    }   
    return 0;
}

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...