• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > 如何将后缀表达式转换为中缀表达式?c或者c++实现。

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

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了中缀表达式求值c++,中缀表达式转后缀,中缀表达式转后缀求值,中缀表达式后缀表达式,中缀表达式等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:如何将后缀表达式转换为中缀表达式?c或者c++实现。
描述:

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


解决方案1:

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

算法思路:

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

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

  2. 如果是运算符op,则从栈顶弹出两个元素a和b,然后将(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;
}


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2017-06-07 python生成快速的文件
  • 2017-06-07 (golang)Vim下Gofmt等插件的运行问题
  • 2017-06-07 iOSnsmutalblearrayaddobject程序崩溃
  • 2017-06-07 错错错一错再错pythonscrapy爬虫错误
  • 2017-06-07 升级AndroidSDK七牛有类似趣拍的sdk吗?android
  • 2017-06-07 (laravel)生产环境Composer怎么平滑Update
  • 2017-06-07 关于Flask-login的user_loader的问题
  • 2017-06-07 七牛表单上传生成token问题
  • 2017-06-07 求不定积分有段正则搞不定,求帮忙
  • 2017-06-07 python中mainloop是如何循环的?

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 用kNN算法识别手写数字,归一化对准确率的影响?
    • 如何使用Python图形库绘制扇形?
    • Python爬虫抓取代理IP
    • Python:如何让scons强制重编译?
    • 七牛云70的SDK私有下载
    • (flask)Web程序中的全局变量,有些问题想不通
    • jbosstools插件的问题
    • javascrip字符串转数组
    • 正则匹配手机号后四位至少有一个是8?如何写?
    • pythonexcept中的e是什么意思?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有