2013北理上机-中缀转后缀

本文详细介绍了如何将中缀表达式转换为后缀表达式,重点阐述了利用栈进行转换的算法思想,包括操作数的处理、括号的处理以及操作符的比较和入栈规则。此外,还强调了转换过程中的边界条件和细节问题。
摘要由CSDN通过智能技术生成

改了很长时间,到处出错,很难过

1.注意每次输入都要进行Inf.clear();

2.解决了迭代器遍历类型不匹配的warning:

for(vector<char>::size_type i=0; i<str.length(); i++)

3.最重要的还是把思路搞明白,注意各种细节,边界条件,以及如果利用比较优先级弹栈,可以将'('设置为优先级最低,这样任何操作符和'('比较时,直接进行压栈。

4.另外刚发现可以写成:

postf.push_back(op_st.top());
op_st.pop();
不改了,懒

5.算法思想:

         首先我们在进行后缀表达式转换为后缀表达式的过程中,利用了一种常见的数据结构:栈。我们利用栈先进后出的特性进行转换操作。该栈用于存储表达式中的操作符:

+、-、*、/、(、)

         所以,我们将该栈称作为操作符栈。

         借助于栈这种数据结构,我们的算法逻辑

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值