LINL631 2021-04-07 20:11 采纳率: 75%
浏览 13
已采纳

输入算式(#号结束输入):9+(7-3)*[9/(8-5)]#,按照预设应该打印ok,

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define STACK_INIT_SIZE 20    //栈的容量

typedef int Status;
typedef char ElemType;

typedef struct 
{
    int base;
    int top;
    int stacksize;
    char data[STACK_INIT_SIZE];
}SqStack;

//初始化
void InitStack(SqStack& S)
{
    S.top = -1;     //初始化栈顶
}

//创建
Status Create(SqStack& L)
{
    L.base = (int)malloc(STACK_INIT_SIZE * sizeof(int));
    if (!L.base)
    {
        printf("存储分配失败\n");
        return 0;
    }
    L.top = L.base;
    L.stacksize = STACK_INIT_SIZE;
    return 1;
}

//判断栈是否为空
Status StackEmpty(SqStack& S)
{
    if (S.top == -1)    //栈空
    {
        return 1;
    }
    else
    {
        return 0;
    }
}

//入栈
Status Push(SqStack& S, ElemType x)
{
    if (S.top == STACK_INIT_SIZE - 1)
    {
        return 0;
    }
    S.top = S.top + 1;
    S.data[S.top] = x;
    return 1;
}

//出栈
Status Pop(SqStack& S, ElemType x)
{
    if (S.top == -1)    //栈空
    {
        return 0;
    }
    x = S.data[S.top];  //栈顶元素出栈
    S.top = S.top - 1;
    return 1;
}

//判断括号
Status Check(char str[], int length)
{
    SqStack S;
    InitStack(S);   //初始化
    for (int i = 0; i < length; i++)
    {
        if ((str[i] == '(') || (str[i] == '['))     //为左括号则入栈
        {
            Push(S, str[i]);
        }  
        else
        {
            if (StackEmpty(S))
            {
                return 0;
            }
            char topElem = 0;
            Pop(S, topElem);

            //匹配出现错误的情况
            if ((str[i] == ')') && (topElem != '('))
            {
                return 0;
            }
            if ((str[i] == ']') && (topElem != '['))
            {
                return 0;
            }
        }
    }
    return StackEmpty(S);
}

int main()
{
    int i = 0;
    char str[19],ch;
    int len = strlen(str);
    //输入算式,输入#结束
    while ((ch = getchar()) != '#')
    {
        str[i++] = ch;
    }
    str[i] = '\0';
    if (Check(str, len))
    {
        printf("ok");
    }
    else
    {
        printf("error");
    }

}

 

  • 写回答

1条回答 默认 最新

  • lemon-l 2021-04-08 00:57
    关注

    Status Pop(SqStack& S, ElemType x);ElemType应该用引用。否则取不到栈顶值

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!