标签: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