表达式计算(递归实现)

表达式求值

题目:输入为s四则运算表达式,仅由数字、+、-、*、/、(、)组成,没有空格,要求求其值。假设运算符结果倒是整数。“/”结果也是整数。

代码实现:

#include<iostream>
using namespace std;

int expression_value();

int factor_value() //计算因子的值,因子可以是一个整数或括号里的数 
{
	char a;
	int n;
	a = cin.peek();
	if(a == '(')
	{
		cin.get();
		n = expression_value();
		cin.get(); //把右括号读取 
	}
	else{//如果是整数的话直接返回
		cin>>n;
	}
	return n;
}

int term_value() //计算项的值,项是一个因子或者多个因子的乘除 
{
	int n;
	n = factor_value();
	char a;
	a = cin.peek();
	if(a=='*')
	{
		cin.get();
		return n*term_value();
	}
	else if(a == '/')
	{
		cin.get();
		return n/term_value();
	}
	else
		return n;
}


int expression_value() //计算表达式的值,表达式是一个项或多个项的加减 
{
	int n;
	n = term_value();
	char a;
	a = cin.peek();
	if(a=='+')
	{
		cin.get();
		return n+expression_value();
	}else if(a=='-')
	{
		cin.get();
		return n-expression_value();
	}else
		return n;
	
}

int main()
{
	cout<<expression_value()<<endl;
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值