c语言实现逆波兰表达式!

C语言实现逆波兰表达式(栈的应用)

 #include<iostream>
 #include<cstdio>
 using namespace std;
 const int MAXSIZE = 110;
 char a[MAXSIZE];
 double operNum[MAXSIZE];
 ​
 double getSum(int* i){//地址传递,可以在边求值时边改变i的原值。如若是值传递,会导致值的重复算
  double sum = 0.0;
  int k = 0;
  while(a[*i] >= '0' && a[*i] <= '9'){
  sum = sum * 10 + a[*i] - '0';
  (*i)++;
  }
  if(a[*i] == '.'){
  (*i)++;
  while(a[*i] >= '0' && a[*i] <= '9'){
  sum = sum * 10 + a[*i] - '0';
  (*i)++;
  k++;
  }
  }
  while(k!=0){
  sum /= 10;
  k--;
  }
  return sum;
 }
 int main(){
  gets(a);//这样可以读入空格,要求以'#'结尾
 
  int i=0;
  int top=0;
  double x1,x2;
  while (a[i] != '#'){
  if(a[i] >= '0' && a[i] <= '9'){
  double f = getSum(&i);
  operNum[top++] = f;
  }else if(a[i] == ' '){
  i++;
  }else if(a[i] == '+'){
  x1 = operNum[--top];
  x2 = operNum[--top];
  operNum[top++] = x1 + x2;
  i++;
  }else if(a[i] == '-'){
  x1 = operNum[--top];
  x2 = operNum[--top];
  operNum[top++] = x2 - x1;
  i++;
  }else if(a[i] == '*'){
  x1 = operNum[--top];
  x2 = operNum[--top];
  operNum[top++] = x1 * x2;
  i++;
  }else if(a[i] == '/'){
  x1 = operNum[--top];
  x2 = operNum[--top];
  operNum[top++] = x2 / x1;
  i++;
  }
  }
 
  cout<<operNum[0]<<endl;
  return 0;
 }

 

posted @ 2021-03-15 16:26  how_you_make_me_feel  阅读(550)  评论(0编辑  收藏  举报