后缀表达式的计算

作者: 芒果和小猫 | 来源:发表于2017-12-06 19:38 被阅读0次

1、栈

栈是一种只允许一端操作的线性数据结构,具有LIFO(last in first out)的特点,具有广泛的应用,如我在游戏编程模式--命令模式(2)中使用栈的结构来实验撤销、重做功能。现在打算用栈结构来实现后缀表达式的计算。

2、后缀表达式

后缀表达式,指的是不包含括号,运算符放在两个运算对象的后面,所有的计算按运算符出现的顺序,严格从左向右进行(不再考虑运算符的优先规则)。

例如 5+(2+3)*4 转换为后缀表达式为 523+4*+

3、后缀表达式的计算

规则:从左向右扫描,遇到数字压栈,遇到操作符,弹出栈顶的两个元素,先弹出的元素在右边,后弹出来的在左边,进行计算后,将结果压栈,再往后扫描,直到扫描结束,输出栈顶元素,即为最终结果。
523+4*+为例
5压栈 2压栈 3压栈 遇到+号,弹出3 2,计算2+3,将5压栈,此时栈为5 5,将4压栈,遇到*号,弹出4 5,计算5*4,将20压栈 此时栈为5 20 ,遇到+号,计算5+20,将25压栈,扫描结束,输出25。
以上就是计算过程。下面用C++编写代码,为了方便标记算式的结束,在末尾我们加上#,用来标识算式结束,这里我们只进行四则运算

#include <iostream>
#include <stack>
#include "string"
using namespace std;

int main()
{
    stack<int> a;
    string temp;
    cin >> temp;
    int i = 0;
    while (true)
    {
        if (temp[i]=='#') cout << a.top(); break;
        if (temp[i]<='9'&&temp[i]>='0') a.push(temp[i]-48);
        else
        {
            int x, y;
            y = a.top(); a.pop();
            x = a.top(); a.pop();
            switch (temp[i])
            {
            case '+':a.push(x + y); break;
            case '-':a.push(x - y); break;
            case '*':a.push(x * y); break;
            case '/':a.push(x / y); break;
            default:break;
            }
        }
        ++i;        
    }
    cin >> temp;
    return 0;
}

相关文章

  • day06-逆波兰表达式的计算器

    目标:完成一个逆波兰表达式的计算器(分为两个步骤)计算后缀表达式:中缀表达式转成后缀表达式: 1.计算后缀表达式:...

  • 逆波兰计算器

    中缀表达式转换成后缀表达式 后缀表达式的计算 逆波兰计算器 先挖坑,学年设计之后再来填坑。

  • 计算器

    使用Java写的一个可以计算+,-,*,/ 的计算器。首先用栈把中缀表达式转化成后缀表达式,再利用栈对后缀表达式求...

  • [堆栈] 前, 中, 后缀表达式

    将中缀表达式转换成后缀表达式(逆波兰式), 便于计算机的计算.

  • 机试常用算法和题型-栈和队列专题

    堆栈+ordermap使用括号匹配 堆栈使用简单计算器 栈+队列实现中缀转后缀,计算后缀表达式 栈+队列计算,包括...

  • 堆栈

    堆栈中常见的问题: 问题1: 后缀表达式怎么计算?问题2: 中缀表达式怎么转换成后缀表达式?问题3: 回溯算法问题...

  • Python 简单计算器-逆波兰后缀表达式实现

    中缀表达式 后缀表达式 简易计算器,可以通过栈来实现。然而如果直接使用中缀表达式,需要处理括号,而使用后缀表达式则...

  • 栈的应用

    中缀表达式转换为后缀表达式 后缀表达式 做数学运算时,经常使用的是中缀表达式,即“操作数 运算符 操作数”。在计算...

  • 计算器专题

    0X00 基础知识 后缀表达式的计算 150. 逆波兰表达式求值 后缀表达式就是这么简单粗暴,碰到一个符号,就从栈...

  • 【Python】(十)后缀表达式

    python实现栈的代码回顾 后缀表达式回顾 后缀表达式是计算机科学中的一种常见的数学表达式形式。相比于人类常用的...

网友评论

    本文标题:后缀表达式的计算

    本文链接:https://www.haomeiwen.com/subject/hqvlixtx.html