递归求前缀表达式的值

目录

1.加减乘除的前缀表达式求值

问题描述

所用知识

代码

运行结果

 2.加、减、乘、除、平方、取反的前缀表达式求值

 问题描述

代码

 运行结果

1.加减乘除的前缀表达式求值

问题描述

输入带空格的前缀表达式求其值

样例

输入:

+ 3 4

输出:

7

所用知识

1.函数递归。

2.stringstream对象取子串。stringstream对象能取出被空格隔开的子串。

代码

#include<iostream>
#include<sstream>
#include<stdlib.h>
using namespace std;
double f(stringstream &s)
{
	string w;
	s>>w;
	if(w=="+")return f(s)+f(s);
	else if(w=="-")return f(s)-f(s);
	else if(w=="/")return f(s)/f(s);
	else if(w=="*")return f(s)*f(s);
	else return atoi(w.c_str());
}
int main()
{
	char a[100];
	cin.getline(a,100);
	stringstream s(a); 
	cout<<f(s);
	return 0;
}

运行结果

 2.加、减、乘、除、平方、取反的前缀表达式求值

 问题描述

自定义运算函数如:add(加),sub(减),mult(乘),div(除以),neg(取反),doubleMe(平方)求前缀表达式的值。

样例

输入:

add sub neg 4 12  mult doubleMe 2 5

输出:

4

所用知识

1.函数递归。

2.stringstream对象取子串。stringstream对象能取出被空格隔开的子串。

代码

#include<iostream>
#include<sstream>
#include<stdlib.h>
#include<cmath>
#include"windows.h"
using namespace std;
double f(stringstream &s)
{
	string w;
	s>>w;
	if(w=="add")return f(s)+f(s);
	else if(w=="sub")return f(s)-f(s);
	else if(w=="div")return f(s)/f(s);
	else if(w=="mult")return f(s)*f(s);
	else if(w=="neg")return -f(s);
	else if(w=="doubleMe")return pow(f(s),2);
	else return atoi(w.c_str());
}
int main()
{
	char a[1000];
	cin.getline(a,1000);
	stringstream s(a); 
	cout<<f(s)<<endl;
	return 0;
}

 运行结果

 欢迎指正!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

晓零清

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值