首页 > 代码库 > 字符串四则运算
字符串四则运算
#include<iostream>//中缀表达式求值
#include<stack>
using namespace std;
int precede(char t1,char t2) //shuru//判断优先级
{
int t=0;
switch(t2)
{
case ‘+‘:
case ‘-‘:
if(t1==‘(‘||t1==‘#‘) t=-1;
else t=1;
break;
case ‘*‘:
case ‘/‘:
if(t1==‘*‘||t1==‘/‘||t1==‘)‘)
t=1;
else t=-1;
break;
case ‘#‘:
if(t1==‘#‘) t=0;
else t=1;
break;
case ‘(‘:
t=-1;
break;
case ‘)‘:
if(t1==‘(‘) t=0;
else t=1;
break;
}
return t;
}
int operate(int m,char cp,int n)//就算
{
switch(cp)
{
case ‘+‘:
return m+n;
case ‘-‘:
return m-n;
case ‘*‘:
return m*n;
case ‘/‘:
return m/n;
}
return 0;
}
int main()
{
int m,n;
char cp;
stack<int> open;
stack<char> optr;
optr.push(‘#‘);//初始化
char input[]="3*(4+2)/2-5#";
int i=0;
while(input[i]!=‘\0‘)
{
if(input[i]>=‘0‘&&input[i]<=‘9‘)
open.push(input[i]-‘0‘);
else
switch(precede(optr.top(),input[i]))
{
case 1:
while(precede(optr.top(),input[i])==1)
{
m=open.top();
open.pop();
n=open.top();
open.pop();
cp=optr.top();
optr.pop();
open.push(operate(n,cp,m));
}
if(precede(optr.top(),input[i])==-1)
optr.push(input[i]);
else optr.pop();
break;
case -1:
optr.push(input[i]);
break;
case 0:
optr.pop();
break;
}
i++;
}
cout<<open.top()<<endl;
return 0;
}
#include<stack>
using namespace std;
int precede(char t1,char t2) //shuru//判断优先级
{
int t=0;
switch(t2)
{
case ‘+‘:
case ‘-‘:
if(t1==‘(‘||t1==‘#‘) t=-1;
else t=1;
break;
case ‘*‘:
case ‘/‘:
if(t1==‘*‘||t1==‘/‘||t1==‘)‘)
t=1;
else t=-1;
break;
case ‘#‘:
if(t1==‘#‘) t=0;
else t=1;
break;
case ‘(‘:
t=-1;
break;
case ‘)‘:
if(t1==‘(‘) t=0;
else t=1;
break;
}
return t;
}
int operate(int m,char cp,int n)//就算
{
switch(cp)
{
case ‘+‘:
return m+n;
case ‘-‘:
return m-n;
case ‘*‘:
return m*n;
case ‘/‘:
return m/n;
}
return 0;
}
int main()
{
int m,n;
char cp;
stack<int> open;
stack<char> optr;
optr.push(‘#‘);//初始化
char input[]="3*(4+2)/2-5#";
int i=0;
while(input[i]!=‘\0‘)
{
if(input[i]>=‘0‘&&input[i]<=‘9‘)
open.push(input[i]-‘0‘);
else
switch(precede(optr.top(),input[i]))
{
case 1:
while(precede(optr.top(),input[i])==1)
{
m=open.top();
open.pop();
n=open.top();
open.pop();
cp=optr.top();
optr.pop();
open.push(operate(n,cp,m));
}
if(precede(optr.top(),input[i])==-1)
optr.push(input[i]);
else optr.pop();
break;
case -1:
optr.push(input[i]);
break;
case 0:
optr.pop();
break;
}
i++;
}
cout<<open.top()<<endl;
return 0;
}
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。