一:思路分析
初始化两个栈:运算符栈s1和储存中间结果的栈s2
从左至有扫描中缀表达式
遇到操作数时,将其压入s2
遇到运算符时,比较其与s1栈顶运算符的优先级:
- 如果s1为空,或栈顶运算符为左括号“(”,则直接将次运算符入栈
- 否则,若优先级比较栈顶运算符的高,也将运算符压入s1
- 否则,将s1栈顶的运算符弹出并压入到s2中,再次将(4-1)与s1中心耳朵栈顶运算符想比较
遇到括号时:
- 如果是左括号“(”,则直接压入s1
- 如果是右括号“)”,则依次弹出s1栈顶的运算符,并压入s2,直到遇到左括号为止,此时将这一对括号丢弃
重复2至5,直到表达式的最右边
将s1中剩余的运算符依次弹出并压入s2
依次弹出s2中的元素并输出,结果的逆序即为中缀表达式对应的后缀表达式
1
中缀表达式1+((2+3)*4)-5==>后缀表达式123+4*+5-
二:代码实现
1 | public List<string> parseSuffixExpressionList(List<string> ls) |