C语言基础--栈的应用之逆波兰式 后缀计算机应用

中缀:3+5

后缀:3 5 +

3+4*2-1 转后缀为 4 2 * 3 + 1 -

 

 

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "stack.h"
int reversed_cal(char *s)
{
    int res = 0, a, b;
    char *p = s;

    if (s == NULL)
        return 0;

    p = strtok(s, " ");
    push(atoi(p));
    while ((p = strtok(NULL, " ")) != NULL)
    {
        switch (*p) 
        {
            case '+':b = pop(); a = pop(); res = a+b; push(res);break;
            case '-':b = pop(); a = pop(); res = a-b; push(res);break;
            case '*':b = pop(); a = pop(); res = a*b; push(res);break;
            case '/':b = pop(); a = pop(); res = a/b; push(res);break;
            default: push(atoi(p));
        }
    }
    return pop();
}
int main(void)
{
    int res;
    //char str[] = "64 4 + 2 / 3 *";
    char str[100];
    gets(str);

    init_stack(100);

    res = reversed_cal(str);
    printf("%d\n", res);

    destory_stack();

    return 0;
}

 

posted @ 2015-09-26 14:52  微博和csdn还有你  阅读(392)  评论(0编辑  收藏  举报