算术表达式有前缀表示法、中缀表示法和后缀表示法等形式。前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4。请设计程序计算前缀表达式的结果值。
输入格式:
输入在一行内给出不超过30个字符的前缀表达式,只包含+、-、*、/以及运算数,不同对象(运算数、运算符号)之间以空格分隔。
输出格式:
输出前缀表达式的运算结果,保留小数点后1位,或错误信息ERROR。
输入样例:
+ + 2 * 3 - 7 4 / 8 4
输出样例:
13.0
看了许多个版本,有用c++几十行搞定的大佬,奈何我c++刚刚入门,太多语法不熟练,只能再去学习c语言大佬的思路。这里的思路是借鉴了 @Z. Jia 这位博主的思路。
我再把它消化为自己的理解;
总结如下:
【算法】:
由于该题数字与运算符之间相隔一个空格 利用scanf 字符串不读取空格的特性 分离成一块一块
分别是数字,运算符,将这两块处理完入栈大S
其中数字需要经过处理转化为double型的数字
转化过程要注意,带正负符号以及带小数点
带正负符号的情况:c[0]为非数字而c[1]为数字;带小数点的情况:在c[i]为数字的情况下 c[i+1]是小数点
处理完数字直接入栈大S

最低0.47元/天 解锁文章
2937

被折叠的 条评论
为什么被折叠?



