N—E—E 2021-10-21 11:44 采纳率: 59.5%
浏览 75
已结题

这个判断左右括号输入是否正确的程序哪里错了

比如【】正确,【{】}错误
每次无论输入啥都是输出“bye”是为啥。

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

struct Node;
typedef struct Node *Stack;
typedef struct Node *PtrToNode;

bool IsEmpty(Stack);
void Push(Stack S,char value);
void Pop(Stack S);
int Top(Stack S);
Stack CreateStack(); //“格式化”一个栈
void MakeEmpty(Stack S);
struct Node
{
    char ch;
    PtrToNode next;
};

#include "Stack-link.h"

bool IsEmpty(Stack S){
    return S->next == NULL;
}
void Push(Stack S,char value){
    PtrToNode new_cell;
    new_cell = malloc(sizeof(struct Node));
    if (IsEmpty(S))
    {
        S->next = new_cell;
        new_cell->next = NULL;
        new_cell->ch = value;
    }
    else
    {
        new_cell->next = S->next;
        S->next = new_cell;
        new_cell->ch = value;
    }
}
void Pop(Stack S){

    PtrToNode temp;
    if (IsEmpty(S))
        printf("Empty stack!!!");
    else
    {
        temp = S->next;
        S->next = temp->next;
        free(temp);
    }
}
int Top(Stack S){
    if (!IsEmpty(S))
        return S->next->ch;
    printf("Empty stack!!!");
    return 0;
}
Stack CreateStack(){
    Stack S;
    S=malloc(sizeof(struct Node));
    S->ch = 'h';
    if (S == NULL)
        printf("Out of space!!!");
    else
        S->next = NULL;
    MakeEmpty(S);
    return S;
} //初始化一个栈
void MakeEmpty(Stack S){
    if (S == NULL)
        printf("You must creat a stack first!");
    else
    {
        while (!IsEmpty(S))
        {
            Pop(S);
        }
        
    }
}


int main()
{
    char ch;
    bool judge = true;
    Stack s = CreateStack();
    fputs("Please enter the test line:",stdout);
    while ((ch = getchar()) != EOF)
    {
    
            if (ch == '{' || ch == '[' || ch == '(')
                Push(s,ch);
            else
            {
                switch (ch)
                {
                    case '}':
                        if (Top(s) != '{') judge = false;
                        break;
                    case ']':
                        if (Top(s) != '(') judge = false;
                        break;
                    case ')':
                        if (Top(s) != '(') judge = false;
                        break;
                    default:
                        break;
                }
                if (judge != false) Pop(s);
            }
            if (judge == false) fputs("false!",stdout); break;
            
            

        
    }
    fputs("bye!",stdout);
    return 0;

}

  • 写回答

3条回答 默认 最新

  • Autumn0923 2021-10-21 14:11
    关注

    先上结果:

    #include <stdbool.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    struct Node;
    typedef struct Node *Stack;
    typedef struct Node *PtrToNode;
    bool IsEmpty(Stack);
    void Push(Stack S,char value);
    void Pop(Stack S);
    int Top(Stack S);
    Stack CreateStack(); //“格式化”一个栈
    void MakeEmpty(Stack S);
    struct Node
    {
        char ch;
        PtrToNode next;
    };
    
    
    
    bool IsEmpty(Stack S){
        return S->next == NULL;
    }
    
    
    
    void Push(Stack S,char value){
        PtrToNode new_cell;
        new_cell = (PtrToNode)malloc(sizeof(struct Node));
        if (IsEmpty(S))
        {
            S->next = new_cell;
            new_cell->next = NULL;
            new_cell->ch = value;
        }
        else
        {
            new_cell->next = S->next;
            S->next = new_cell;
            new_cell->ch = value;
        }
    }
    void Pop(Stack S){
        PtrToNode temp;
        if (IsEmpty(S))
            printf("Empty stack!!!");
        else
        {
            temp = S->next;
            S->next = temp->next;
            free(temp);
        }
    }
    int Top(Stack S){
        if (!IsEmpty(S))
            return S->next->ch;
        return 0;
    }
    Stack CreateStack(){
        Stack S;
        S=(Stack)malloc(sizeof(struct Node));
        S->ch = 'h';
        if (S == NULL)
            printf("Out of space!!!");
        else
            S->next = NULL;
        MakeEmpty(S);
        return S;
    } //初始化一个栈
    void MakeEmpty(Stack S){
        if (S == NULL)
            printf("You must creat a stack first!");
        else
        {
            while (!IsEmpty(S))
            {
                Pop(S);
            }
        }
    }
     
    int main()
    {
        int ch;
        bool judge = true;
        Stack s = CreateStack();
        fputs("Please enter the test line:",stdout);
        while ((ch = getchar()) != EOF && ch != '\n')
        {
            if (ch == '{' || ch == '[' || ch == '(')
                Push(s,ch);
            else
            {
                switch (ch)
                {
                    case '}':
                        if (Top(s) != '{') judge = false;
                        break;
                    case ']':
                        if (Top(s) != '[') judge = false;
                        break;
                    case ')':
                        if (Top(s) != '(') judge = false;
                        break;
                    default:
                        break;
                }
                if (judge != false) 
                {
                    Pop(s);    
                    fputs("Yes! ",stdout);
                }
            }
            if (judge == false) 
            {
                fputs("false! ",stdout);
                while (!IsEmpty(s))
                {
                    Pop(s);
                }
                judge = true;
            }
        }
        fputs("\nbye!",stdout);
        return 0;
    }
    

    img

    首先 fputs 我没用过我看你用的这我就用你的这改了一下,你这个代码只输出bye是因为你的循环直接就跳出来了,你看你这一行 if (judge == false) fputs("false!",stdout); break; 你这个代码执行一遍就直接break了,后面就没法跑,所以就直接bye了,这是一个逻辑问题所以建议以后还是 if 后面的语句都写到大括号里,不然就容易犯这种错误,这也直接导致我看了半天没看出来是这问题,哈哈哈,以后小心点哦
    还有一个就是主函数里面的ch变量最好是int类型的,你想想(ch = getchar()) != EOF这句话里EOF等于-1,那char类型哪里来的-1,所以要改成int类型,这里牵扯到一个字符集的问题,就不细说了,这种方法你再输入的时候是停不下来的需要你手动输入EOF,windows下输入方法是ctrl+z输入,当然你要不想专门输入一个EOF你可以像我一样加个条件
    还有一个就是在你的createstack函数里面,我发现你这么写了,我有点没搞懂

        S=(Stack)malloc(sizeof(struct Node));
        S->ch = 'h';
        if (S == NULL)
    

    你看你先给s分配空间,然后又给s->赋值,那只有分配好了才能赋值么,所以我觉得你的s==null应该写到赋值的前面去

    以上就是我个人观点,如果你还有什么问题可以私信我

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月30日
  • 已采纳回答 10月22日
  • 创建了问题 10月21日

悬赏问题

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