IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言栈的应用——中缀表达式转后缀表达式 -> 正文阅读

[C++知识库]C语言栈的应用——中缀表达式转后缀表达式

算法思路

a+b+(c-d)*e转换为后缀表达式,从左向右读取,读取到数字的时候(这里例子里面是字母),就将数字直接添加到后缀表达式中;遇到操作符时,将读取到的操作符与栈中元素进行对比,如果读取的操作符的优先级小于等于栈中的操作符,就将栈中的操作符弹出并添加到后缀表达式中,并且将读取的操作符压入栈中,否则直接将操作符压入栈中。

具体转化过程

  1. 读取到数字a,将数字a添加到postfixList的末端;此时postfixList=['a'](postfixList表示后缀表达式)

  2. 读取到操作符+,此时操作符栈op为空,直接将操作符压入栈中;此时栈op=['+'](为了方便演示,使用数组表示栈)

  3. 读取到数字b,将数字b添加到postfixList的末端;此时postfixList=['a','b']

  4. 读取到操作符'+',因为只有'(''+','-'优先级小,所以将栈op中除了'('所有操作符弹出,此时postfixList=['a','b','+'],栈op=['+']

  5. 读取到操作符'(',优先级最小,直接压入栈中,此时postfixList=['a','b','+'],栈op=['+','(']

  6. 读取到数字c,将数字c添加到postfixList的末端,此时postfixList=['a','b','+','c']

  7. 读取到操作符'-',因为op栈顶元素'('优先级较小,直接将'-'压入栈中,此时栈op=['+','(','-']

  8. 读取到数字d,将数字d添加到postfixList的末端,此时postfixList=['a','b','+','c','d']

  9. 读取到操作符')',将栈中'('上面所有的元素全部弹出并添加到postfixList末端,并将'('删除,此时postfixList=['a','b','+','c','d','-'],栈op=['+']

  10. 读取到操作符'*',因为'*'比栈顶元素'+'优先级高,所以直接压入栈中,此时栈op=['+','*']

  11. 读取到数字e,将数字e添加到postfixList的末端,此时postfixList=['a','b','+','c','d','-','e']

  12. 中缀表达式全部读取完毕,如果栈op未空,将栈op的所有元素弹出并添加到postfisList末尾,最后输出postfixList即为转化完成的后缀表达式,此时postfixList=['a','b','+','c','d','-','e','*','+']

  13. 所以中缀表达式a+b+(c-d)*e转化为后缀表达式为ab+cd-e*+

代码实现

// 中缀表达式转后缀表达式
void InfixToPostfix()
{
    int length, i, j=0;  // 定义表达式长度
    LiStack op;    // 定义op操作符栈
    op = initStack();

    char infixList[100],postfixList[100] = {0};;  // infixList保存中缀表达式,初始化postfixList,postfixList保存操作完之后的后缀表达式

    printf("请输入中缀表达式:\n");
    scanf("%s", infixList);
    getchar();
    length = (int) strlen(infixList);

    // 主循环
    for (i = 0; i < length; i++)
    {
        if (isdigit(infixList[i]))      // 判断是否为数字,isdigit函数包含在"ctype.h"头文件中,如果为数字则返回1,否则返回0
        {
            postfixList[j++] = infixList[i];    // 如果是数字,将数字直接添加到后缀表达式末尾
        }
        else
        {
            if (infixList[i] == '(')   // 如果是左括号,直接压入栈中
            {
                push(op, infixList[i]);
            }
            else if (infixList[i] == ')')    // 如果是右括号,将左括号前的所有操作符添加到后缀表达式末尾
            {
                while (top(op) != '(')  // 如果栈顶不是左括号,将栈顶元素添加到后缀表达式末尾
                {
                    postfixList[j++] = (char)pop(op);
                }
                pop(op);    // 弹出左括号
            }
            else    // 如果是其他操作符,则按照优先级进行
                    // 若读取的操作符优先级等于或低于当前栈顶元素,将栈顶元素弹出添加到后缀表达式末尾
            {
                if (infixList[i] == '+' || infixList[i] == '-')     // +或-优先级最小
                {
                    if (stackEmpty(op))      // 如果栈空,直接压入
                    {
                        push(op, infixList[i]);
                    }
                    else    // 栈中除了左括号'('其他的都弹出
                    {
                        while (!stackEmpty(op) && ((char)top(op) != '('))
                        {
                            postfixList[j++] = (char) pop(op);
                        }
                        push(op, infixList[i]);     // 最后将+或-压入栈中
                    }
                }
                else    // *或/,如果栈顶为+或-,压入栈中
                {
                    if ((char)top (op) == '+' || (char)top (op) == '-' || (char)top (op) == '(')
                    {
                        push(op, infixList[i]);
                    }
                    else
                    {
                        postfixList[j++] = (char) pop(op);
                        push(op, infixList[i]);

                    }
                }
            }
        }
    }

    while (!stackEmpty(op))
    {
        postfixList[j++] = (char)pop(op);
    }

    printf("%s\n", postfixList);
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-10 13:14:33  更:2021-08-10 13:15:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/10 1:47:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码