逆波兰表达式(信息学奥赛一本通-T1198)
生活随笔
收集整理的這篇文章主要介紹了
逆波兰表达式(信息学奥赛一本通-T1198)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
【題目描述】
逆波蘭表達式是一種把運算符前置的算術表達式,例如普通的表達式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
【源程序】
#include<iostream> #include<cstdio> #include<cstdlib> using namespace std; char a[55]; double calculate() {scanf("%s",a);if(a[0]=='+')return calculate()+calculate();else if(a[0]=='-')return calculate()-calculate();else if(a[0]=='*')return calculate()*calculate();else if(a[0]=='/')return calculate()/calculate();elsereturn atof(a); } int main() {printf("%f\n",calculate());return 0; }?
總結
以上是生活随笔為你收集整理的逆波兰表达式(信息学奥赛一本通-T1198)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 求最长不下降序列(信息学奥赛一本通-T1
- 下一篇: 最大子树和(洛谷-P1122)