洛谷P1175 表达式的转换
P1175 表达式的转换
- 44通过
- 147提交
- 题目提供者该用户不存在
- 标签云端
- 难度提高+/省选-
- 时空限制1s / 128MB
提交 讨论 题解
最新讨论更多讨论
- 这题有毒
- 抄题解棒责五十!
- 题面上的“—”是个什么鬼。…
- 关于题意的小疑问
题目描述
平常我们书写的表达式称为中缀表达式,因为它将运算符放在两个操作数中间,许多情况下为了确定运算顺序,括号是不可少的,而中缀表达式就不必用括号了。
后缀标记法:书写表达式时采用运算紧跟在两个操作数之后,从而实现了无括号处理和优先级处理,使计算机的处理规则简化为:从左到右顺序完成计算,并用结果取而代之。
例如:8–(3+2*6)/5+4可以写为:8 3 2 6*+5/–4+
其计算步骤为:8 3 2 6 * + 5 / – 4 +
8 3 12 + 5 / – 4 +
8 15 5 / – 4 +
8 3 – 4 +
5 4 + 9
编写一个程序,完成这个转换,要求输出的每一个数据间都留一个空格。
输入输出格式
输入格式:
就一行,是一个中缀表达式。输入的符号中只有这些基本符号“0123456789+-*/^()”,并且不会出现形如2*-3的格式。
表达式中的基本数字也都是一位的,不会出现形如12形式的数字。
所输入的字符串不要判错。
输出格式:
若干个后缀表达式,第I+1行比第I行少一个运算符和一个操作数,最后一行只有一个数字,表示运算结果。
输入输出样例
8–(3+2*6)/5+4
8 3 2 6 * + 5 / – 4 +
8 3 12 + 5 / – 4 +
8 15 5 / – 4 +
8 3 – 4 +
5 4 +
9
说明
运算的结果可能为负数,“/”以整除运算。并且中间每一步都不会超过2^31。
分析:中缀表达式转换为后缀表达式的一个解法:
0.定义一个栈.
1.遇到数,输出.
2.碰到左括号,直接压到栈顶.
3.碰到一个运算符,如果栈顶元素是左括号,直接压入栈顶,否则,从栈顶开始,把比这个运算符优先级大的给输出,然后压进去.
4.碰到右括号,将元素不断弹出直到遇到左括号.
那么如何进行计算呢?可以发现运算符是按照运算先后顺序出现的,我们只需要将字符串转化为数字,然后枚举到运算符直接运算及可.
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <queue>
#include <stack> using namespace std; string s,s1;
int sizee,top,num[]; stack <char> k; void add(char ss)
{
s1 += ss;
s1 += ' ';
} bool check(char t)
{
if (k.empty() || k.top() == '(') //千万不要打反了,血的教训
return true;
if (k.top() == '^')
return false;
if (t == '^')
return true;
if (k.top() == '*' || k.top() == '/')
return false;
if (t == '*' || t == '/')
return true;
return false;
} void jisuan(char x)
{
int a = num[top--], b = num[top--],t = ;
if (x == '+')
t = a + b;
if (x == '-')
t = b - a;
if (x == '*')
t = a * b;
if (x == '/')
t = b / a;
if (x == '^')
t = pow(b, a);
num[++top] = t;
} void solve()
{
for (int i = ; i < sizee; i++)
{
if (s[i] >= '' && s[i] <= '')
add(s[i]);
else
{
if (s[i] == '(')
k.push(s[i]);
else
{
if (s[i] == ')')
{
while (k.top() != '(')
{
add(k.top());
k.pop();
}
k.pop();
}
else
{
if (!check(s[i]))
{
while (!check(s[i]))
{
add(k.top());
k.pop();
}
}
k.push(s[i]);
}
}
}
}
while (!k.empty())
{
add(k.top());
k.pop();
}
cout << s1 << endl;
} void print()
{
for (int i = ; i < s1.size(); i++)
{
if (s1[i] >= '' && s1[i] <= '')
num[++top] = s1[i] - '';
else
{
if (s1[i] == ' ')
continue;
jisuan(s1[i]);
i++;
for (int j = ; j <= top; j++)
printf("%d ", num[j]);
for (int j = i + ; j < s1.size(); j++)
printf("%c", s1[j]);
cout << endl;
}
}
} int main()
{
cin >> s;
sizee = s.size();
solve();
print(); return ;
}
洛谷P1175 表达式的转换的更多相关文章
- 中后缀表达式/洛谷P1175 表达式的转换
P1175 表达式的转换 思路:先用栈转成中缀表达式,再用栈进行计算.要输出过程,因此计算一次输出一次,但是栈没有迭代器,不好用,换成vector(可以pop_back).虽然表达式求值也可以这么做, ...
- 洛谷P1017 进制转换
洛谷P1017 进制转换 题目描述 我们可以用这样的方式来表示一个十进制数: 将每个阿拉伯数字乘以一个以该数字所处位置的(值减1)为指数,以10为底数的幂之和的形式.例如:123可表示为 \(1*10 ...
- 洛谷p1017 进制转换(2000noip提高组)
洛谷P1017 进制转换 题意分析 给出一个数n,要求用负R进制显示. n∈[-32768,32767].R ∈[-20,-2] 考察的是负进制数的转换,需要理解短除法. 看到这道题的时候,我是比较蒙 ...
- 洛谷P1310 表达式的值 题解 栈/后缀表达式的应用
题目链接:https://www.luogu.org/problem/P1310 本题涉及算法:栈.前缀表达式转后缀表达式,动态规划思想. 这道题目我思考了好长时间,第一时间让我做的话我也做不出来. ...
- 洛谷 P1017 进制转换
推荐洛谷 题目描述 我们可以用这样的方式来表示一个十进制数: 将每个阿拉伯数字乘以一个以该数字所处位置的(值减1)为指数,以10为底数的幂之和的形式.例如:123可表示为 1*10^2+2*10^1+ ...
- 2019.06.17课件:[洛谷P1310]表达式的值 题解
P1310 表达式的值 题目描述 给你一个带括号的布尔表达式,其中+表示或操作|,*表示与操作&,先算*再算+.但是待操作的数字(布尔值)不输入. 求能使最终整个式子的值为0的方案数. 题外话 ...
- 洛谷P1310 表达式的值——题解
题目传送 题的难点:1.有运算优先级,不好判断.2.有破坏整体和谐性的讨厌的括号.3.不知道哪里要填数.4.要求方案数很大,搜索不会做呐. 发现难点1和2都是中缀表达式的缺点.转成后缀表达式后难点1. ...
- 洛谷P2084 进制转换
题目背景 无 题目描述 今天小明学会了进制转换,比如(10101)2 ,那么它的十进制表示的式子就是 : 1*2^4+0*2^3+1*2^2+0*2^1+1*2^0, 那么请你编程实现,将一个M进制的 ...
- 洛谷 P1739 表达式括号匹配
题目链接https://www.luogu.org/problemnew/show/P1739 题目描述 假设一个表达式有英文字母(小写).运算符(+,—,*,/)和左右小(圆)括号构成,以“@”作为 ...
随机推荐
- PAT (Basic Level) Practise (中文)- 1003. 我要通过!(20)
http://www.patest.cn/contests/pat-b-practise/1003 “答案正确”是自动判题系统给出的最令人欢喜的回复.本题属于PAT的“答案正确”大派送 —— 只要读入 ...
- hadoop install
1.home下建立hadoop 2.在Downloads下解压hadoop-2.6.0.tar.gz 3.将解压后的hadoop-2.6.0移动到/home/hadoop 4.csf@ubuntu:/ ...
- C# 接口慨述
接口(interface)用来定义一种程序的协定.实现接口的类或者结构要与接口的定义严格一致.有了这个协定,就可以抛开编程语言的限制(理论上).接口可以从多个基接口继承,而类或结构可以实现多个接口.接 ...
- React后台管理系统-商品管理列表组件
1.商品列表页面结构 <div id="page-wrapper"> <PageTitle title="商品列表" ...
- 第17题:打印1到最大的n位数
面试题17:打印1到最大的n位数 题目:输入数字n,按顺序打印出从1最大的n位十进制数.比如输入3,则打印出1.2.3一直到最大的3位数即999. 考点: 用字符串或者数组表达一个大数. 思路 1. ...
- maven引入dubbo包后启动报错
启动后报错内容为: Caused by: org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exce ...
- k8s资源配置清单的书写格式(yaml文件)
yaml文件书写格式:5大类:apiVersion: 选择kubectl api-versions里面存在的版本kind: 选择kubectl api-resources结果中的对象资源metadat ...
- 面试前赶紧看了5道Python Web面试题,Python面试题No17
目录 本面试题题库,由公号:非本科程序员 整理发布 第1题: Flask中的请求上下文和应用上下文是什么? 第2题:django中间件的使用? 第3题: django开发中数据做过什么优化? 第4题: ...
- win10桌面显示我的电脑
1.桌面单击右键菜单栏,选中单击个性化 2.选择主题->桌面图标设置 3.勾选需要显示或不显示的图标
- python-01 spider原理
用Python可以做什么?可以做日常任务,比如自动备份你的MP3:可以做网站,很多著名的网站包括YouTube就是Python写的:可以做网络游戏的后台,很多在线游戏的后台都是Python开发的.总之 ...