如何将后缀表达式转换为中缀表达式?c或者c++实现。

发布于 2022-09-02 09:52:37 字数 27 浏览 17 评论 0

中缀转换成后缀的我会,倒过来就通不过了。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

﹉夏雨初晴づ 2022-09-09 09:52:37

“从后缀转中缀”比“从中缀转后缀”要简单,因为不需要处理运算符优先级的问题。

算法思路:

从左到右扫描后缀表达式中的符号,有两种情况:

  1. 如果是数字,则直接压栈。

  2. 如果是运算符op,则从栈顶弹出两个元素ab,然后将(a op b)压栈。

最后栈顶的结果就是一个等价的中缀表达式,当然可能会有多余的括号,但不影响正确性。

下面是一个C++的实现,假设输入的后缀表达式是有效的,没有考虑错误处理。

#include <stack>
#include <vector>
#include <string>
#include <iostream>
using namespace std;
string postfix_to_infix(vector<string> expr) {
    stack<string> s;
    for (int i = 0; i < expr.size(); ++i) {
        // a number
        if (!expr[i].empty() && expr[i][0] >= '0' && expr[i][0] <= '9') {
            s.push(expr[i]);
        }
        // an operator
        else {
            string second = s.top(); s.pop();
            string first = s.top(); s.pop();
            s.push("(" + first + expr[i] + second + ")");
        }
    }
    return s.top();
}
int main() {
    vector<string> expr = {"3", "2", "5", "-", "6", "*", "3", "/", "+"};
    // output: (3+(((2-5)*6)/3))
    cout << postfix_to_infix(expr) << endl;
    return 0;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文