郁闷的C小加(一)

时间限制:1000 ms  |  内存限制:65535 KB
难度:3
 
描述

我们熟悉的表达式如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小加(一) 前缀表达式变后缀的更多相关文章

  1. NYOJ 257 郁闷的C小加(一) (字符串处理)

    题目链接 描述 我们熟悉的表达式如a+b.a+b(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说)操作符在两个操作数中间:num1 operand num2.同理,后缀表达式就是操作符 ...

  2. NYOJ 257 郁闷的C小加(一)

    郁闷的C小加(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度: 描写叙述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说) ...

  3. nyoj 257 郁闷的C小加(一)(栈、队列)

    郁闷的C小加(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...

  4. NYOJ 409 郁闷的C小加(三) (字符串处理)

    题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...

  5. NYOJ 267 郁闷的C小加(二) (字符串处理)

    题目链接 描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考"郁闷的C小加(一)"),C小加很高兴.但C小加是个爱思考的人,他又想通过这种方法计算一个表达式的值 ...

  6. nyoj 409——郁闷的C小加(三)——————【中缀式化前缀后缀并求值】

    郁闷的C小加(三) 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很 ...

  7. NYOJ-267 郁闷的C小加(二)

    郁闷的C小加(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:4   描述 聪明的你帮助C小加解决了中缀表达式到后缀表达式的转换(详情请参考“郁闷的C小加(一)”),C小加很 ...

  8. 郁闷的C小加(一)(后缀表达式)

    郁闷的C小加(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...

  9. NYOJ--257--郁闷的C小加(一)(中缀表达式变后缀表达式 )

    郁闷的C小加(一) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 我们熟悉的表达式如a+b.a+b*(c+d)等都属于中缀表达式.中缀表达式就是(对于双目运算符来说 ...

随机推荐

  1. Linux内核学习方法

    Makefile不是Make Love 从前在学校,混了四年,没有学到任何东西,每天就是逃课,上网,玩游戏,睡觉.毕业的时候,人家跟我说Makefile我完全不知,但是一说Make Love我就来劲了 ...

  2. 2016 系统设计第一期 (档案一)jQuery ajax serialize()方法form提交数据

    jQuery ajax serialize()方法form提交数据,有个很奇怪的问题,好像不能取到隐藏控件的值. //点击提交按钮保存数据 $('#btn_submitUser').click(fun ...

  3. JAVA类与对象(三)----类定义关键字详解

    static 表示静态,它可以修饰属性,方法和代码块. 1.static修饰属性(类变量),那么这个属性就可以用类名.属性名来访问,也就是使这个属性成为本类的类变量,为本类对象所共有.这个属性就是全类 ...

  4. css的display属性小实验

    div与span是常用的盒子模型; 区别: div默认是垂直分布(独占一行)   span默认是水平分布(一行可以有多个) 通过float属性可以改变div容器的分布方式达到span容器的效果; 下面 ...

  5. C++中的冒泡排序,选择排序,插入排序

    最简单的插入排序:思想,两两之间比较,时间复杂度o(n^2) void bubblesort(vector<int>&vec, int n) { if (&vec==NUL ...

  6. python学习小结4:类

    虽然Python是解释性语言,但是它是面向对象的,能够进行对象编程. 类和对象是面向对象编程的两个主要方面.类:创建一个新类型,而对象是这个类的实例,类使用class关键字创建.类的域和方法被列在一个 ...

  7. arcgis for server 登陆manager失败解决办法

    版本是 arcgis for server 10.02 症状 1. manager网页无法打开http://localhost:6080/arcgis/manager/ 2. 查看服务无法启动,启动后 ...

  8. 1304: [CQOI2009]叶子的染色 - BZOJ

    Description给一棵m个结点的无根树,你可以选择一个度数大于1的结点作为根,然后给一些结点(根.内部结点和叶子均可)着以黑色或白色.你的着色方案应该保证根结点到每个叶子的简单路径上都至少包含一 ...

  9. MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能

    MYSQL-实现ORACLE- row_number() over(partition by ) 分组排序功能 由于MYSQL没有提供类似ORACLE中OVER()这样丰富的分析函数. 所以在MYSQ ...

  10. smarty中的母板极制_extends和block标签

    模板继承 继承是从面向对象编程而来的概念,模板继承可以让你定义一个或多个父模板,提供给子模板来进行扩展. 扩展继承意味着子模板可以覆盖部分或全部父模板的块区域. 继承结构可以是多层次的,所以你可以继承 ...