美文网首页
中缀表达式转换为后缀表达式

中缀表达式转换为后缀表达式

作者: 鹿与云与雨 | 来源:发表于2019-11-27 15:43 被阅读0次

所谓中缀表达式,指的是运算符处于操作数的中间(例:3 * ( 4 + 2 )),中缀表达式是人们常用的算术表示方法,但中缀表达式不容易被计算机解析,因为既要考虑运算符的优先级,还要考虑括号的处理。但中缀表达式仍被许多程序语言使用,因为它符合人们的普遍用法。后缀表达式,指的是不包含括号,运算符放在两个操作数的后面,所有的计算按运算符出现的顺序,严格从左向右进行(不再考虑运算符的优先规则,也不需要考虑括号)。

给出一个中缀表达式,请将其转换为后缀表达式并输出。

//有部分测试未通过
#include <iostream>
#include<stack>
#include<cstring>
#include<string>
#include<map>
using namespace std;

int main()
{
    int i = 0, k, j;
    string str;
    stack<char>s;
    map<char, int>mp;
    getline(cin, str);
    bool test = true;
    mp['-'] = 1, mp['+'] = 1;
    mp['*'] = 2, mp['/'] = 2;
    mp['('] = 3, mp[')'] = 3;
    while (i <= str.length())
    {
        if (str[i] == ' ')
        {
            i++;
            continue;
        }
        if (((i == 0 || str[i - 1] == '(') && (str[i] == '+' || str[i] == '-')) || (str[i] >= '0' && str[i] <= '9'))
        {
            if (!test)         //正常
            {
                cout << " ";
            }
            if (str[i] != '+')
            {
                cout << str[i];
            }
            while (str[i + 1] >= '0' && str[i + 1] <= '9')
            {
                cout << str[i];
            }
            test = false;
        }
        else {
            if (str[i] >= '0' && str[i] <= '9')
            {
                cout << str[i];
                cout << ' ';
            }
            else if (str[i] == ')')
            {
                while (!s.empty() && s.top() != '(')
                {
                    cout << ' ' << s.top();
                    s.pop();
                }
                s.pop();
            }
            else if (s.empty() || mp[str[i]] > mp[s.top()])
            {
                s.push(str[i]);
            }
            else {
                while (!s.empty() && s.top() != '(')

                {
                    cout << ' ' << s.top();
                    s.pop();
                }
                s.push(str[i]);
            }
        }
        i++;
    }
    while (!s.empty())
    {
        cout << s.top() << ' ';
        s.pop();
    }
    return 0;
}

相关文章

  • 表达式树

    表达式树中缀表达式转换为后缀表达式后缀表达式总结

  • 栈的应用

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

  • 四则运算(JAVA)

    计算过程 1.将四则运算串分割出中缀表达式2.将中缀表达式转换为后缀表达式3.对后缀表达式进行求值得出结果

  • 四则运算表达式求值

    利用栈求解四则运算:求解思路为先将中缀表达式转换为后缀表达式,再利用后缀表达式求解中缀表达式:运算符出现在两个数字...

  • 数据结构与算法--后缀表达式

    中缀表达式转后缀表达式 中缀表达式转后缀表达式的思路步骤分析。 初始化一个栈和一个队列,运算符栈 S1 和存储中间...

  • 中缀表达式转后缀表达式并求值

    1.什么是中缀表达式?中缀表达式示例 2.什么是后缀表达式?后缀表达式示例 3.代码

  • C语言中缀表达式计算器

    本文将介绍中缀表达式计算器的详细写法,是 C语言把中缀表达式转换为后缀表达式 和 C语言逆波兰计算器 的结合 ...

  • C语言的基于栈实现的表达式求值

    一、目的 理解中缀表达式求值的过程 理解中缀转后缀表达式求值的过程 掌握堆栈的应用 二、问题描述 缀表达式,其中包...

  • C语言的基于栈实现的表达式求值

    一、目的 理解中缀表达式求值的过程 理解中缀转后缀表达式求值的过程 掌握堆栈的应用 二、问题描述 缀表达式,其中包...

  • 前缀,中缀,后缀表达式

    全文转载自:前缀、中缀、后缀表达式(逆波兰表达式),侵删。 前缀表达式,中缀表达式,后缀表达式都是四则运算的表达方...

网友评论

      本文标题:中缀表达式转换为后缀表达式

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