前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >波兰表达式

波兰表达式

作者头像
mathor
发布2018-06-22 10:32:26
1.1K0
发布2018-06-22 10:32:26
举报
文章被收录于专栏:mathormathor

说明:

波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的波兰表达式为+ 2 3。波兰表达式的优点是运算符之前不必有优先级关系,也不用括号改变运算次序,例如(2+3)*4的波兰表示法为* + 2 3 4,求解波兰表达式的值,其中运算符包括+-*/四个。

样例输入:* + 11.0 12.0 + 24.0 35.0

样例输出:1357.000000

提示:(11.0+12.0)*(24.0+35.0)

解法:

波兰表达式的定义:

(1)一个数是波兰表达式,值为该数.

(2)波兰表达式的形式为:“运算符 波兰表达式 波兰表达式”,值为两个波兰表达式的值运算的结果.

其实我们仔细看第二点,就会发现,这是一个很明显的递归,“波兰表达式 = 运算符 波兰表达式 波兰表达式”,而第一点类似于递归的出口,当一个数是波兰表达式时,值为该数.

C:

代码语言:javascript
复制
#include <bits/stdc++.h>
using namespace std;
double exp()
{
        char s[20];
        cin>>s;
        switch(s[0])
        {
               case'+':return exp()+exp();
               case'-':return exp()-exp();
               case'*':return exp()*exp();
               case'/':return exp()/exp();
               default:return atof(s);//如果为数,则直接返回这个数 
               break;
        } 
} 
int main()
{
        printf("%lf",exp());
        return 0;
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档