C++项目中如何实现一个栈计算器?

写一个栈计算器

写一个栈计算器,设计如下:

  • 支持 +-*/运算

  • 支持后缀输入

例如:

2 3 +

输出:

5

堆操作可以总结如下:

  • push:将一个元素添加到栈顶部

  • pop:从栈顶部移除该元素

  • top: 获取栈顶部元素的值

  • empty: 检查栈是否为空

如何实现呢?

其中最关键两个问题:

1.如何分词

2.如何实现栈

预告:如何写一个简单的短链接程序?

1.如何分词

首先定义好输入是一个字符串,空格风格,我们便可以使用istringstream分割每一个token了,基本框架为:

std::istringstream iss(expression);
std::string token;
while (iss >> token) {
}

2.如何实现栈

对于计算器来说,最核心就是入栈、出栈。

  • 碰到数字入栈

  • 碰到操作符出栈计算

我们便可以写出框架:

if (isNumber(token)) {
  pushNumber(token);
} else if (isOperator(token)) {
  popAndCal(token);
} else {
  throw std::runtime_error("Invalid token in expression.");
}

popAndCal是计算的核心,如:

void popAndCal(const std::string& token) {
  if (operandStack.size() < 2) {
    throw std::runtime_error("Invalid expression.");
  } else {
    double operand2 = operandStack.top();
    operandStack.pop();
    double operand1 = operandStack.top();
    operandStack.pop();
    double result = performOperation(operand1, operand2, token);
    operandStack.push(result);
  }
}

那么我们在栈中变存储了我们想要的结果,最后返回top即可。

是不是很简单,欢迎与我一起探讨。

本节的所有代码已上传星球,感兴趣的可以去里面获取。

c0e3d4f55efbbf59c21e46d78394b8ac.jpeg


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值