求中缀表达式的值 学习笔记

题目描述

在这里插入图片描述
分析:表达式是由项通过加减构成的,项是由因子通过乘除构成的

程序代码

#include <iostream>
#include <cstdlib>
#include <cstring>

using namespace std;

int expression_value();

int factor_value() {			//读入一个因子并返回它的值
	int result = 0;
	char c = cin.peek();
	if (c == '(') {
		cin.get();
		result = expression_value();
		cin.get();
	}
	else {
		while (isdigit(c)) {
			result = 10 * result + c - '0';
			cin.get();
			c = cin.peek();
		}
	}
	return result;
}

int term_value() {				//读入一项并返回它的值
	int result = factor_value();
	while (true) {
		char op = cin.peek();
		if (op == '*' || op == '/') {
			cin.get();
			int value = factor_value();
			if (op == '*') result *= value;
			else result /= value;
		}
		else break;
	}
	return result;
}

int expression_value() {		//求一个表达式值
	int result = term_value();	//求第一项的值
	bool more = true;
	while (more) {
		char op = cin.peek();	//cin.peek()看输入流中第一个字符,且不将其取出
		if (op == '+' || op == '-') {
			cin.get();			//cin.get()取走输入流第一个字符
			int value = term_value();
			if (op == '+') result += value;
			else result -= value;
		}
		else more = false;
	}
	return result;
}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值