繁体   English   中英

C:堆栈转储错误,以将后缀转换为后缀

[英]C: Stack Dump error for infix to postfix conversion

我已经编写了以下代码,用于将中缀表达式转换为后缀,但显示运行时错误。

错误如下:

输入字符串:a + bc * d 1 [main] infix_to_postfix 7340 cygwin_exception :: open_stackdumpfile:将堆栈跟踪信息转储到infix_to_postfix.exe.stackdump

以下是我的代码:

#include<stdio.h>
#include<string.h>
#define size 20

struct stack{
    int a[size],top;
    int temp[size], tos;
}s;

// Push operation....
void push(struct stack s,int item){
    if(s.top >= size-1){
        printf("\nStack overflow..\n");
    }
    else{
        s.a[++s.top] = item;
    }
}

// Pop operation....
int pop(struct stack s){
    if(s.top == -1){
        printf("\n..Stack underflow..\n");
}
else {
    return s.a[s.top--];
}
}


// function f starts from here. f returns the precedence value of corresponding symbol.
int f(char symbol){
    if (symbol == '+' || '-')
        return 1;
    if (symbol == '*' || '/')
        return 2;
    if (symbol == '#')
        return 0;
    char c;
for(c='a'; c<='z'; c++){
    if(symbol == c)
        return 3;
}
}

int main(){
s.top = -1;
s.a[++s.top] = '#';

int i = 0;
char input[20], polish[21];
char next, temp;

printf("Input string: ");
scanf("%s", input);
strcat(input, '#');
next = input[i++];

while(next != '\0'){
    while(f(next) > f(s.a[s.top])){
        push(s, next);
        next = input[i++];
    }
    while(f(next) <= f(s.a[s.top])){
        temp = pop(s);
        strcat(polish, temp);
        printf("\nPolish: %s", polish);
    }
}


return 0;
}
strcat(polish, temp);

永远不会初始化polish因此使用未初始化的数组会导致未定义的行为。 strcat()需要以空值结尾的字符串。

尝试做类似的事情

char polish[21] = "";

编辑:

正如@BLUEPIXY指出的, strcat()期望使用char *不是char

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM