判断序列是否为正确的出栈序列
创始人
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;
}

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...