码迷,mamicode.com
首页 > 其他好文 > 详细

中缀表达式求值的方法—栈

时间:2020-05-20 18:55:48      阅读:44      评论:0      收藏:0      [点我收藏+]

标签:两个栈   string   define   namespace   using   replace   NPU   char   sum   

对于像是1+2的中缀表达式,我们可以轻松地运用代码来算出结果。

但是对于1+(2^2)/3*4这样的表达式,事情就变得有些复杂了...

对于上述的表达式,我们可以运用栈的相关知识来解决—建立两个栈,栈1放数字,栈2放运算符;遇到数字时入栈1;遇到运算符时,若栈2为空,则pop出栈1中的两个数运算,将运算完的结果压入栈1;若栈2非空,则将当前运算符与栈2中栈顶的运算符进行比较优先级,再进行下一步操作。代码如下:

#include <iostream>
#include <string.h>
#include <math.h>
#include <stack>
#define Maxsize 50
using namespace std;
stack<int> S1;
stack<char> S2;
void Calculate(char a)
{
int b,c,d=0;
if(a==‘+‘){
b=S1.top();
S1.pop();
c=S1.top();
S1.pop();
d=c+b;
S1.push(d);
}
if(a==‘-‘){
b=S1.top();
S1.pop();
c=S1.top();
S1.pop();
d=c-b;
S1.push(d);
}
if(a==‘*‘){
b=S1.top();
S1.pop();
c=S1.top();
S1.pop();
d=c*b;
S1.push(d);
}
if(a==‘/‘){
b=S1.top();
S1.pop();
c=S1.top();
S1.pop();
d=c/b;
S1.push(d);
}
if(a==‘^‘){
b=S1.top();
S1.pop();
c=S1.top();
S1.pop();
d=pow(c,b);
S1.push(d);
}
}
int main()
{
char a[50],e;
int num;
int sum=0;
cin.getline(a,50);
for(int i=0;i<strlen(a);i++){
if(a[i]>=‘0‘&&a[i]<=‘9‘){
num=0;
while((a[i]>=‘0‘&&a[i]<=‘9‘)){
num=num*10+(a[i]-‘0‘);
i++;
}
S1.push(num);
//cout<<S1.top()<<endl;
i--;
}
if(!isdigit(a[i])){
if(S2.empty()){
S2.push(a[i]);
//cout<<S2.top()<<endl;
}
//^
else if(a[i]==‘^‘){
if(S2.top()!=‘^‘) S2.push(a[i]);
else{
while(!S2.empty()&&S2.top()==‘^‘){
Calculate(S2.top());
S2.pop();
}
S2.push(a[i]);
}
}
//* /
else if(a[i]==‘*‘||a[i]==‘/‘){
while(!S2.empty()&&S2.top()!=‘+‘&&S2.top()!=‘-‘&&S2.top()!=‘(‘){
Calculate(S2.top());
S2.pop();
}
S2.push(a[i]);
}
//+ -
else if(a[i]==‘+‘||a[i]==‘-‘){
while(!S2.empty()&&S2.top()!=‘(‘){
Calculate(S2.top());
S2.pop();
}
S2.push(a[i]);
}
else if(a[i]==‘(‘) S2.push(a[i]);
else if(a[i]==‘)‘){
while(!S2.empty()&&S2.top()!=‘(‘){
Calculate(S2.top());
S2.pop();
}
S2.pop();
}
}
}
while(!S2.empty()){
Calculate(S2.top());
S2.pop();
}
cout<<int(S1.top());
return 0;
}

运用c++需要用到118行代码,但是运用python,一行代码就可以解决,python代码如下:

print(eval(input().replace(‘/‘,‘//‘).replace(‘^‘,‘**‘)))

人生苦短,我用python。

中缀表达式求值的方法—栈

标签:两个栈   string   define   namespace   using   replace   NPU   char   sum   

原文地址:https://www.cnblogs.com/lgrdeboke/p/12925045.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!