后缀表达式求值

为了便于处理表达式,常常将普通表达式(称为中缀表示)转换为后缀 { 运算符在后,如 X/Y 写为 XY/ 表达式。在这样的表示中可以不用括号即可确定求值的顺序,如: (P+Q)*(R S) → PQ+RS * 。后缀表达式的处理过程如下:扫描后缀表达式,凡遇操作数则将之压进堆栈,遇运算符则从堆栈中弹出两个操作数进行该运算,将运算结果压栈,然后继续扫描,直到后缀表达式被扫描完毕为止,此时栈底元素即为该后缀表达式的值。//

输入一行表示后缀表达式,数与数之间一定有空格隔开(可能不只一个空格),最后输入@表示输入结束。

数据保证每一步的计算结果均为不超过100000的整数。

代码:

#include<iostream>
#include<stdio.h>
#include<fstream>
#include<cstdlib>
using namespace std;
#define MAXSIZE 10000
#define OK 1
#define ERROR 0
#define OVERFLOW -2

typedef struct
{
 int *top;
 int *base;
 int stacksize;
} Sq;
Sq S1;

int InitStack(Sq &S1)
{
 S1.base = new int[MAXSIZE];
 if(!S1.base)
        exit(OVERFLOW);
 S1.top = S1.base;
 S1.stacksize = MAXSIZE;
 return OK;
}

int Push(Sq &S1, int g)
{
 *S1.top++ = g;
 return OK;
}

int Pop(Sq &S1)
{
 int g;
 g = *--S1.top;
 return g;
}

int Input(char m[MAXSIZE])
{
 int h = 0;
 for(; m[h - 1] != '@'; h++)
 {
  m[h] = getchar();
 }
 m[h] = '\0';
    return OK;
}

int Did(char m[MAXSIZE])
{
 int h = 0;
 int g = 0;
 for(; m[h] != '@'; h++)
 {
  int k;
  char j;
  if(m[h] >= '0' && m[h] <= '9')
  {
   g = g * 10 + m[h] - '0';
  }
  else
   if((m[h] == ' ' || m[h] == '+' || m[h] == '-' || m[h] == '/' || m[h] == '*') && m[h-1] >= '0' && m[h-1] <= '9')
   {
    k = g;
    g = 0;
    Push(S1, k);
   }
   if(m[h] == '+' || m[h] == '-' || m[h] == '/' || m[h] == '*')
    goto area;
   else
    {
area:    j = m[h];
     switch(j)
     {
     case '+':
      {
       int c;
       c = Pop(S1);
       int d;
       d = Pop(S1);
       Push(S1, d + c);
       break;
      }
     case '-':
      {
       int c;
       c = Pop(S1);
       int d;
       d = Pop(S1);
       Push(S1, d - c);
       break;
      }
     case '*':
      {
       int c;
       c = Pop(S1);
       int d;
       d = Pop(S1);
       Push(S1, d * c);
       break;
      }
     case '/':
      {
       int c;
       c = Pop(S1);
       int d;
       d = Pop(S1);
       Push(S1, d / c);
       break;
      }
     default:
      break;
     }
   }
 }
    return OK;
}


int main()
{
 InitStack(S1);
 char m[MAXSIZE];
 Input(m);
 Did(m);
 int result = Pop(S1);
 cout << result << endl;
}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值