【递归】openjudge 逆波兰表达式 2694

     在函数里面等待输入,当输入的是运算符的时候,我会等待输入两个数字来进行运算,如果输入的还是运算符,我们可以继续等待,直至输入数字,返回结果与相应的运算符进行运算。

     这里根据逆波兰表达式的定义进行递归求解。在递归函数中,针对当前的输入有5种情况:1。输入是常数,则表达式的值就是这个常数;2.输入的是‘+’,则表达式的值是再继续读入两个表达式并计算出他们的值,然后将他们的值进行相加;3.输入‘-’;4.输入是‘*’;5.输入是‘/’;后三种情况与2.相同,只是计算从‘+’变成‘-’,‘*’,‘/’。

#include<stdio.h>
#include<stdlib.h>
#include<iostream>
#include<string.h>
#include <ctype.h>
#include<string>
#include<algorithm>
#include<vector>
#include<math.h> 
using namespace std;
char str[10];
double dfs()
{
	scanf("%s",str);
	switch(str[0])
	{
		case'+':return dfs()+dfs();
		case'-':return dfs()-dfs();
		case'*':return dfs()*dfs();
		case'/':return dfs()/dfs();
		default:return atof(str);
	}
}
int main()
{
   double ans=dfs();
   printf("%lf\n",ans);
   return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值