博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
波兰表达式
阅读量:4540 次
发布时间:2019-06-08

本文共 1195 字,大约阅读时间需要 3 分钟。

题目:

 

逆波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的逆波兰表示法为+ 2 3。逆波兰表达式的优点是

运算符之间不必有优先级关系,也不必用括号改变运算次序,例如(2 + 3) * 4的逆波兰表示法为* + 2 3 4。本题求解逆波兰

表达式的值,其中运算符包括+ - * /四个。输入输入为一行,其中运算符和运算数之间都用空格分隔,运算数是浮点数。输出

输出为一行,表达式的值。可直接用printf("%f\n", v)输出表达式的值v。样例输入

 

* + 11.0 12.0 + 24.0 35.0

样例输出

1357.000000

这里先列一个网站,是波兰表达式的维基百科,让读者弄明白什么是波兰表达式,即前缀表达式。题目中的逆波兰表达式实际上

是错误的。

 

https://zh.wikipedia.org/wiki/%E6%B3%A2%E5%85%B0%E8%A1%A8%E7%A4%BA%E6%B3%95

 

对于波兰表达式的运算顺序,我觉得这张图看懂的话,就不会再有任何的问题。

 

- * / 15 - 7 + 1 1 3 + 2 + 1 1 = - * / 15 - 7   2   3 + 2 + 1 1 = - * / 15     5     3 + 2 + 1 1 = - *        3       3 + 2 + 1 1 = -          9         + 2 + 1 1 = -          9         + 2   2   = -          9         4         =                5 关于这道题目的思想就是栈的思想,还有就是递归的思路。
#include 
using namespace std;char s[1005];double f() {scanf("%s",s);switch(s[0]){ case '+':return f()+f(); case '-':return f()-f(); case '*':return f()*f(); case '/':return f()/f(); default:return atof(s);}}int main(){ printf("%f",f()); return 0;}

  

这种解法我觉得是比较高级的解法,核心思想就是每次都从字符串中读入一个字符,然后通过switch语句选择分路,这个函数唯一 的出口就是两个读入的数值都是常数值,而不是加减乘除,然后就得到一个结果,结合之前波兰表达式的用法和递归的思路就很方 便解决这个问题。

转载于:https://www.cnblogs.com/xyqxyq/p/9297192.html

你可能感兴趣的文章
[No0000EB]C# 数组(Array)
查看>>
[No0000F0]DataGrid一行Row添加ToolTip,wpf
查看>>
这本书能让你睡得好
查看>>
[转]最好用的离线markdown编辑器Haroopad介绍
查看>>
ImageIO.read() 返回 null
查看>>
Cron表达式简单学习
查看>>
整理了八个开源的 Spring Boot 学习资源
查看>>
VS2010如何使用Visual Studio Online在线服务管理团队资源(在线TFS)
查看>>
.net微信公众号开发——消息与事件
查看>>
如何处理高并发情况下的DB插入
查看>>
[Lua快速了解一下]Lua的model
查看>>
C#操作剪贴板实现复制粘贴
查看>>
模糊查询和聚合函数
查看>>
Beaglebone Black教程使用SSH通过USB和因特网连接Beaglebone Black
查看>>
centos 自带mysql卸载时出现无法卸载情况
查看>>
交通工具(并查集)
查看>>
Java里的集合:List/Set/Map
查看>>
linux内核情景分析之exit与Wait
查看>>
mybatis2入门程序
查看>>
解决html设置height:100%无效的问题
查看>>