JAVA数据结构与算法之栈(四)~ 中缀表达式转换为后缀表达式

2021-02-08 00:16

阅读:349

标签:equals   注意   static   逆序输出   入栈   步骤   数字   说明   有限公司   

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

中缀表达式转后缀表达式思路:

1) 初始化两个栈:运算符栈 s1 和储存中间结果的栈 s2;
2) 从左至右扫描中缀表达式;
3) 遇到操作数时,将其压 s2;
4) 遇到运算符时,比较其与 s1 栈顶运算符的优先级:
    1.如果 s1 为空,或栈顶运算符为左括号“(”,则直接将此运算符入栈;
    2.否则,若优先级比栈顶运算符的高,也将运算符压入 s1;
    3.否则,将 s1 栈顶的运算符弹出并压入到 s2 中,再次转到(4-1)与 s1 中新的栈顶运算符相比较;
5) 遇到括号时:
    (1) 如果是左括号“(”,则直接压入 s1
    (2) 如果是右括号“)”,则依次弹出 s1 栈顶的运算符,并压入 s2,直到遇到左括号为止,此时将这一对括号丢弃
6) 重复步骤 2 至 5,直到表达式的最右边
7) 将 s1 中剩余的运算符依次弹出并压入 s2
8) 依次弹出 s2 中的元素并输出,结果的逆序即为中缀表达式对应的后缀表达式

举例:

将中缀表达式“1+((2+3)×4)-5”转换为后缀表达式的过程如下:
因此结果为 :"1 2 3 + 4 × + 5 –"

代码演示:

/**
 * Copyright (C), 2015-2020, XXX有限公司
 * FileName: dddd
 * Author:   Administrator
 * Date:     2020/4/25 15:41
 * Description:
 * History:
 *           

JAVA数据结构与算法之栈(四)~ 中缀表达式转换为后缀表达式

标签:equals   注意   static   逆序输出   入栈   步骤   数字   说明   有限公司   

原文地址:https://www.cnblogs.com/pierceming/p/12773378.html


评论


亲,登录后才可以留言!