nyoj 409——郁闷的C小加(三)——————【中缀式化前缀后缀并求值】
郁闷的C小加(三)
- 描述
- 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很高兴。但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值。即先把表达式转换为前缀和后缀表达式,再求值。这时又要考虑操作数是小数和多位数的情况。
- 输入
- 第一行输入一个整数T,共有T组测试数据(T<10)。
每组测试数据只有一行,是一个长度不超过1000的字符串,表示这个运算式,每个运算式都是以“=”结束。这个表达式里只包含+-*/与小括号这几种符号。其中小括号可以嵌套使用。数据保证输入的操作数中不会出现负数并且小于1000000。
数据保证除数不会为0。 - 输出
- 对于每组测试数据输出结果包括三行,先输出转换后的前缀和后缀表达式,再输出计算结果,结果保留两位小数。
- 样例输入
-
2
1+2=
(19+21)*3-4/5= - 样例输出
-
+ 1 2 =
1 2 + =
3.00
- * + 19 21 3 / 4 5 =
19 21 + 3 * 4 5 / - =
119.20#include<bits/stdc++.h>
using namespace std;
stack<char>S_tr;//用作后缀表达式运算符存储和前缀表达式存储数字
stack<double>S_nd;//用作存储操作数
stack<char>S_pre_optr;//用作前缀表达式计算中运算符存储
stack<string>S_pre_exp;//用以存放前缀表达式
char suf_exp[1200],suf_exp_i[1200],pre_str[1200];
int m,k,pos;
char suf_compare(char op1,char op2){//转后缀表达式时,比较优先级
// printf(".%c%c.\n",op1,op2);
if(op1=='+'||op1=='-'){
if( op2=='(' || op2=='*' || op2=='/')
return '<';
else return '>';
}
if(op1=='*'||op1=='/'){
if(op2=='(')
return '<';
else return '>';
}
if(op1=='='||op1=='('){
if((op1=='='&&op2=='=')||(op1=='('&&op2==')')){
return '=';
}else{
return '<';
}
}
}
char pre_compare(char a,char b){//转前缀表达式时,比较优先级
if(a=='+'||a=='-'){
if(b=='('||b=='='){
return '>';
}else{
return '<';
}
}
if(a=='*'||a=='/'){
if(b==')'||b=='*'||b=='/'){
return '<';
}else{
return '>';
}
}
if(a==')'||a=='='){
if(a==')'&&b=='('||a=='='&&b=='='){
return '=';
}else{
return '<';
}
}
}
void suf_solve(char a,char b){//求后缀表达式时,当栈顶>当前运算符优先级
if(suf_compare(a,b)=='>'){
suf_exp[m++]=a;//后缀表达式中出现的所有的运算符都在这里放入数组,所以在此加空格
suf_exp[m++]=' ';
suf_exp_i[k++]=a;
S_tr.pop();
suf_solve(S_tr.top(),b);
}else if(suf_compare(a,b)=='<'){
S_tr.push(b);
return;
}else{
S_tr.pop();
return ;
}
}
void pre_solve(char a,char b){//求前缀表达式时,当栈顶>当前运算符优先级
if(pre_compare(a,b)=='>'){
string ts="";
ts+=a;
S_pre_exp.push(ts);
S_pre_optr.pop();
pre_solve(S_pre_optr.top(),b);
}
if(pre_compare(a,b)=='<'){
S_pre_optr.push(b);
return ;
}
if(pre_compare(a,b)=='='){
S_pre_optr.pop();
return;
}
}
double get_num(int po,int len){ //提取数字
double ret=0;
int temp=0,tmp=1,integ=-1;
for(int i=po;i<len;i++){
if(suf_exp[i]==' '||suf_exp[i]=='\0'){
pos=i;
break;
}
if(suf_exp[i]=='.'){
integ=temp;
temp=0;
tmp=1;
continue;
}else{
int tm=suf_exp[i]-'0';
temp*=10;
temp+=tm;
tmp*=10;
}
}
if(integ!=-1)
ret=integ*1.0+temp*1.0/tmp;
else ret=temp*1.0;
return ret;
}
int main(){
int t;
char mid_exp[1200];
scanf("%d",&t);
while(t--){
while(!S_tr.empty()){
S_tr.pop();
}
while(!S_nd.empty())
S_nd.pop();
S_tr.push('=');
m=0;
k=0;
scanf("%s",mid_exp);
int len=strlen(mid_exp);
bool flag=0;
for(int i=0;i<len;i++){
if(mid_exp[i]>='0'&&mid_exp[i]<='9'||mid_exp[i]=='.'){
suf_exp[m++]=mid_exp[i];
suf_exp_i[k++]=mid_exp[i];
flag=1;
}
else{
if(flag==1){
suf_exp[m++]=' ';
flag=0;
}
switch(suf_compare(S_tr.top(),mid_exp[i])){
case '<': S_tr.push(mid_exp[i]);break;
case '>': suf_solve(S_tr.top(),mid_exp[i]);break;
case '=': S_tr.pop();break;
}
}
}
suf_exp_i[k]='\0';
suf_exp[m]='\0';
m++;
strcpy(pre_str+1,mid_exp);
while(!S_tr.empty())
S_tr.pop();
while(!S_pre_exp.empty())
S_pre_exp.pop();
string pre_;
bool flg=0;
pre_str[0]='=';
S_pre_optr.push('=');
for(int i=len-1;i>=0;i--){
if(pre_str[i]>='0'&&pre_str[i]<='9'||pre_str[i]=='.'){
flg=1;
S_tr.push(pre_str[i]);
}else{
if(flg==1){
flg=0;
pre_="";
while(!S_tr.empty()){
pre_+=S_tr.top();
S_tr.pop();
}
S_pre_exp.push(pre_);
}
switch(pre_compare(S_pre_optr.top(),pre_str[i])){
case '<' :S_pre_optr.push(pre_str[i]);break;
case '>' :pre_solve(S_pre_optr.top(),pre_str[i]);break;
case '=' :S_pre_optr.pop(); break;
default : break;
}
}
}
while(!S_pre_exp.empty()){
cout<<S_pre_exp.top()<<" ";
S_pre_exp.pop();
}printf("=");
cout<<endl;
double a,b;
for(int i=0;i<m;i++){
if(suf_exp[i]>='0'&&suf_exp[i]<='9'){
S_nd.push(get_num(i,m));
i=pos;
}else{
switch(suf_exp[i]){ //printf("%.3lf %.3lf\n",a,b);
case '+': b=S_nd.top(),S_nd.pop();a=S_nd.top(),S_nd.pop();S_nd.push(a+b);break;
case '-': b=S_nd.top(),S_nd.pop();a=S_nd.top(),S_nd.pop();S_nd.push(a-b);break;
case '*': b=S_nd.top(),S_nd.pop();a=S_nd.top(),S_nd.pop();S_nd.push(a*b);break;
case '/': b=S_nd.top(),S_nd.pop();a=S_nd.top(),S_nd.pop();S_nd.push(a/b);break;
default : break;
}
}
}
printf("%s%c\n",suf_exp,'=');
printf("%.2lf\n",S_nd.top());
S_nd.pop();
printf("\n");
}
return 0;
}
/*
5
1+((2+3)*4)-5= (19+21)*3-4/5=
9+(3-1)*3+10/2= */
nyoj 409——郁闷的C小加(三)——————【中缀式化前缀后缀并求值】的更多相关文章
- NYOJ 409 郁闷的C小加(三) (字符串处理)
题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...
- NYOJ 257 郁闷的C小加(一) (字符串处理)
题目链接 描述 我们熟悉的表达式如a+b.a+b(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说)操作符在两个操作数中间:num1 operand num2.同理,后缀表达式就是操作符 ...
- NYOJ 257 郁闷的C小加(一)
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度: 描写叙述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说) ...
- nyoj 257 郁闷的C小加(一)(栈、队列)
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
- NYOJ 267 郁闷的C小加(二) (字符串处理)
题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...
- nyoj-257 郁闷的C小加(一) 前缀表达式变后缀
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
- 郁闷的C小加(一)(后缀表达式)
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
- NYOJ-267 郁闷的C小加(二)
郁闷的C小加(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很 ...
- nyoj 236 心急的C小加
心急的C小加 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 C小加有一些木棒,它们的长度和质量都已经知道,需要一个机器处理这些木棒,机器开启的时候需要耗费一个单位的 ...
随机推荐
- WinForm中的多语言处理
配置文件中存储当前语言环境,切换语言时进行修改,启动程序时读取该配置并设置当前线程的Culture 可根据线程的语言环境动态读取不同的资源文件,不同资源文件名用语言环境文本进行区分
- arp欺骗进行流量截获-1
这边博文主要讲一下怎么使用arp欺骗进行流量截获,主要用于已经攻入内网以后,进行流量监听以及修改. 一.什么是arp arp协议是以太网的基础工作协议,其主要作用是是一种将IP地址转化成物理地 ...
- 十一、Node.js监听代码改动自动重启node插件supervisor
我们慢慢地发现,每次我们稍微改变js代码都需要重启服务才能在浏览器显示新的效果,很麻烦,这里我们可以通过npm命令安装supervisoror插件,安装方法如下 之前章节我们知道安装了nodejs就会 ...
- SiriShortCut模型建立及数据交互逻辑
1.模型数据需求 意图: 手机号 密码 网关ID 打开该情景的命令 情景号 情景名 情景背景图 添加该意图时的 token值 主程序登陆共享数据 手机号 token值 2.操作逻辑 1.意图被唤起 获 ...
- Mysql初识数据库《四》mysql安装与基本管理
一.MySQL介绍 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下公司.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方面MySQL是 ...
- kali linux之手动漏洞挖掘一
默认安装漏洞 phpmyadmin/setup默认安装 ubuntu/debian默认安装php5-cgi phpmyadmin/setup默认安装 使用?-d+allow_url_include%3 ...
- 【转】OracleOraDb11g_home1TNSListener服务启动后又停止了
源地址:https://www.cnblogs.com/Asa-Zhu/p/3819605.html 一.错误描述 登陆PL/SQL Developer登陆本地数据库时先报没有监听程序,查看服务发现O ...
- 网页控件很多时最好用绝对定位absolute
否则动一个位置可能影响其他的,牵一发而动全身
- 【bzoj4176】Lucas的数论 莫比乌斯反演+杜教筛
Description 去年的Lucas非常喜欢数论题,但是一年以后的Lucas却不那么喜欢了. 在整理以前的试题时,发现了这样一道题目"求Sigma(f(i)),其中1<=i< ...
- SDUT OJ 数据结构实验之链表九:双向链表
数据结构实验之链表九:双向链表 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descrip ...