nyoj-257 郁闷的C小加(一) 前缀表达式变后缀
郁闷的C小加(一)
- 描述
-
我们熟悉的表达式如a+b、a+b*(c+d)等都属于中缀表达式。中缀表达式就是(对于双目运算符来说)操作符在两个操作数中间:num1 operand num2。同理,后缀表达式就是操作符在两个操作数之后:num1 num2 operand。ACM队的“C小加”正在郁闷怎样把一个中缀表达式转换为后缀表达式,现在请你设计一个程序,帮助C小加把中缀表达式转换成后缀表达式。为简化问题,操作数均为个位数,操作符只有+-*/ 和小括号。
- 输入
- 第一行输入T,表示有T组测试数据(T<10)。
每组测试数据只有一行,是一个长度不超过1000的字符串,表示这个表达式。这个表达式里只包含+-*/与小括号这几种符号。其中小括号可以嵌套使用。数据保证输入的操作数中不会出现负数。并且输入数据不会出现不匹配现象。 - 输出
- 每组输出都单独成行,输出转换的后缀表达式。
- 样例输入
-
2
1+2
(1+2)*3+4*5 - 样例输出
-
12+
12+3*45*+代码:
-
#include<stdio.h>
#include<string.h>
#include<stack>
#include<queue>
using namespace std; char str[];
int f(char a)
{
switch(a)
{
case '-' :
case '+' : return ; break;
case '/' :
case '*' : return ; break;
case '(' : return ; break;
default :return -;
}
} int main()
{
int T;
stack<char>sc;
queue<char>e;
scanf("%d",&T);
while(T--)
{
while(!e.empty())
e.pop();
while(!sc.empty())
sc.pop();
scanf("%s",str);
int len=strlen(str);
sc.push('#');
for(int i=;i<len;++i)
{
if(str[i]>=''&&str[i]<='')
{
e.push(str[i]);
}
else if(str[i]=='(')
{
sc.push(str[i]);
}
else if(str[i]==')')
{
while(sc.top()!='(')
{
e.push(sc.top());
sc.pop();
}
sc.pop();
}
else if(str[i]=='*'||str[i]=='/'||str[i]=='+'||str[i]=='-')
{
char s=sc.top();
while(f(str[i])<=f(s))
{
e.push(s);
sc.pop();
s=sc.top();
}
sc.push(str[i]);
}
}
while(!sc.empty())
{
e.push(sc.top());
sc.pop();
}
while(e.front()!='#')
{
printf("%c",e.front());
e.pop();
}
printf("\n"); }
return ;
}467 代码:添加空格
代码:
#include<stdio.h>
#include<string.h>
#include<stack>
#include<queue>
using namespace std; char str[];
int f(char a)
{
switch(a)
{
case '-' :
case '+' : return ; break;
case '/' :
case '*' : return ; break;
case '(' : return ; break;
default :return -;
}
} int main()
{
int T;
stack<char>sc;
queue<char>e;
scanf("%d",&T);
while(T--)
{
while(!e.empty())
e.pop();
while(!sc.empty())
sc.pop();
scanf("%s",str);
int len=strlen(str);
sc.push('#');
for(int i=;i<len-;++i)
{
if(str[i]>=''&&str[i]<='')
{
if(!e.empty())
e.push(' ');
while(str[i]>=''&&str[i]<=''||str[i]=='.')
{
e.push(str[i]);
i++;
}
i--;
}
else if(str[i]=='(')
{
sc.push(str[i]);
}
else if(str[i]==')')
{
while(sc.top()!='(')
{
e.push(' ');
e.push(sc.top());
sc.pop();
}
sc.pop();
}
else if(str[i]=='*'||str[i]=='/'||str[i]=='+'||str[i]=='-')
{
char s=sc.top();
while(f(str[i])<=f(s))
{
e.push(' ');
e.push(s);
sc.pop();
s=sc.top();
}
sc.push(str[i]);
}
}
while(!sc.empty())
{
e.push(' ');
e.push(sc.top());
sc.pop();
}
while(e.front()!='#')
{
printf("%c",e.front());
e.pop();
}
printf("=\n"); }
return ;
}
nyoj-257 郁闷的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 409 郁闷的C小加(三) (字符串处理)
题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...
- NYOJ 267 郁闷的C小加(二) (字符串处理)
题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...
- nyoj 409——郁闷的C小加(三)——————【中缀式化前缀后缀并求值】
郁闷的C小加(三) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很 ...
- NYOJ-267 郁闷的C小加(二)
郁闷的C小加(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很 ...
- 郁闷的C小加(一)(后缀表达式)
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
- NYOJ--257--郁闷的C小加(一)(中缀表达式变后缀表达式 )
郁闷的C小加(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...
随机推荐
- 批量kill mysql processlist进程
如果大批量的操作能够通过一系列的select语句产生,那么理论上就能对这些结果批量处理.但是mysql并没用提供eval这样的对结果集进行分析操作的功能.所以只能现将select结果保存到临时文件中, ...
- 部署keepalived
下载 keepalived-1.1.20.tar.gz tar -xvf keepalived-1.1.20.tar.gz [root@yoon export]# cd keepalived-1. ...
- asp.net 多个域名重定向,在web.Config中配置
一个网站有多个域名,但是需要在访问其中某个域名之后跳转到另一域名. Web.config 中配置 </system.webServer> <!--重定向 域名 开始--> &l ...
- 2016 系统设计第一期 (档案一)MVC 控制器接收表单数据
1.FormCollection collection user.UserId =Convert.ToInt32(collection["UserId"]); /// < ...
- OC self super isa指针
self指针: self是oc面向对象设计中的一个特殊指针,相当于java中的this,但是比this强大,this只能访问实例对象的相关方法和成员变量,或者说this只代表实例对象: self不仅可 ...
- 【转】android如何浏览并选择图片 音频 视频
转自:http://www.cnblogs.com/top5/archive/2012/03/06/2381986.html 这几天 在学习并开发android系统的图片浏览 音频 视频 的浏览 ...
- iOS$299企业账号In House ipa发布流程
1.在Mac系统中进入“钥匙串访问”,选择“钥匙串访问”-“证书助理”-“从证书颁发机构请求证书”. 填写前两项,并保存在本地. 2.登录https://developer.apple.com,进入i ...
- js收集的一些好的题型
①: var a = {x:1},b=a;var a = a.z = {Y:2}; 求a和b的值? ②: var w = (function a(){return '1'},function b ...
- Eclipse plugin插件开发 NoClassDefFoundError
Eclipse的每一个plugin都有属于自己的类加载器,这是OSGI架构的基础,每一个plugin项目都是一个bundle,独立运行在各自的运行环境里面,这就造成了开发时和运行时的不同. Eclip ...
- hdu2717 Catch That Cow
http://acm.hdu.edu.cn/showproblem.php?pid=2717 //水搜... #include<stdio.h> #include<math.h> ...