我一直在尝试调试这个程序很长时间。当我输入表达式a + b - c或a / b + c第一个运算符的优先级大于或等于第二个运算符时,它可以正常工作。但是对于像a - b / c第一个运算符的优先级低于第二个运算符这样的表达式,编译器会抛出一个断点。
struct stack
{
    char ele;
    struct stack *next;
};
void push(int);
int pop();
int precedence(char);
struct stack *top = NULL;
int main()
{
    char infix[20], postfix[20];
    int i = 0, j = 0;
    printf("ENTER INFIX EXPRESSION: ");
    gets(infix);
    while(infix[i] != '\0')
    {
        if(isalnum(infix[i]))
            postfix[j++] = infix[i];
        else
        {
            if(top == NULL)
                push(infix[i]);
            else
            {
                while( top != NULL && 
                      (precedence(top->ele) >= precedence(infix[i])) ) 
                    postfix[j++]=pop();
                push(infix[i]);
            }
        }
        ++i;
    }
    while(top != NULL)
        postfix[j++] = pop();
    postfix[j] = '\0';
    puts(postfix);
    getchar();
    return 0;
}
int precedence(char x)
{
    switch(x)
    {
    case '^': return 4;
    case '*':
    case '/': return 3;
    case '+':
    case '-': return 2;
    default: return 0;
    }
}
void push(int x)
{
    int item;
    struct stack *tmp;
    if(top == NULL)
    {
        top = (struct stack *)malloc(sizeof(struct stack));
        top->ele = x;
        top->next = NULL;
    }
    else
    {
        tmp = top;
        top->ele = x;
        top->next = tmp;
    }
}
int pop()
{
    struct stack *tmp;
    int item;
    if(top == NULL)
        puts("EMPTY STACK");
    else if(top->next == NULL)
    {
        tmp = top;
        item = top->ele;
        top = NULL;
        free(tmp);
    }
    else
    {
        tmp = top;
        item = top->ele;
        top = top->next;
        free(tmp);
    }
    return item;
}
关于如何改进我的编码的任何建议都会有所帮助。