计算逆波兰式

本文介绍了逆波兰式(后缀表达式)的概念,并提供了一种基于C++和Java的解题思路。通过遍历逆波兰式数组,将操作数压栈,遇到运算符时出栈进行运算。代码中利用函数指针简化运算符判断,确保测试后的结果正确。
摘要由CSDN通过智能技术生成

逆波兰式(Reverse Polish notation,RPN,或逆波兰记法),也叫后缀表达式(将运算符写在操作数之后)。

代码

解题思路:根据逆波兰式的原理,操作符号都在操作数的后面,由此,我们就可以对逆波兰式数组进行遍历,如果是操作数,则先把操作数压入栈中,当发现操作符时,就可以把操作数出栈,进行相应的运算。以下代码假设传入的数组都是正确的逆波兰式,并且操作符都是有2个操作数的。

class RPN {
public:
	typedef int64_t(RPN::*pFun)(int64_t, int64_t);
	unordered_map<string, pFun> mapping;
	RPN() {
		mapping["+"] = &RPN::add;
		mapping["-"] = &RPN::subtract;
		mapping["*"] = &RPN::multiply;
		mapping["/"] 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Z小偉

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

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

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

打赏作者

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

抵扣说明:

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

余额充值