中缀表达式转前缀表达式java实现

本文介绍中缀表达式转换为前缀表达式的算法流程及Java实现,包括运算符优先级比较、栈的使用及计算过程。适用于理解表达式解析及计算器实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

中缀表达式转前缀表达式java实现
准备知识:
前缀、中缀、后缀表达式
http://note.youdao.com/noteshare?id=c27a0ee6222c18ec60cf5bb2154b0744&sub=4CEC6E1E196B4B228839B9220F9F673C

前缀、中缀、后缀表达式和二叉树的关系
http://note.youdao.com/noteshare?id=94f62313f62679a01e7fc6ef5c460dd1&sub=F89CC8CF4BBC44BABCC01C7D360C072C

一、中缀转前缀表达式算法

  • 1、初始化两个栈:运算符栈opStack和存储前缀表达式栈pnStack;
  • 2、【反转】字符串,【从左至右】扫描中缀表达式;
  • 3、遇到操作数时,直接将其压入tempStack中;
  • 4、遇到运算符时,比较其与opStack栈顶运算符的优先级:
  •   4.1、如果opStack为空,或者栈顶运算符为右括号’)’,则直接将此运算符压入opStack中;
    
  •   4.2、否则,若优先级比栈顶运算符的优先级高或相等,则直接将此运算符压入opStack中;
    
  •   4.3、否则,将opStack栈顶的运算符弹出并压入到tempStack中,再次转入步骤4,与opStack中新的栈顶运算符相比较;
    
  • 5、遇到括号时:
  •   5.1、如果是右括号’)’,则直接压入opStack中;
    
  •   5.2、如果是左括号’(‘,则依次弹出opStack栈顶的运算符并压入tempStack中,知道遇到右括号’)’为止,此时将这一对括号丢弃;
    
  • 6、重复步骤2~5,直到表达式的最左边;
  • 7、将opStack中剩余的运算符依次弹出并压入tempStack中;
  • 8、依次弹出tempStack中的元素保存到result中,result即为中缀表达式转换所得的前缀表达式。

二、计算机计算前缀表达式算法

  • 通过前缀表达式计算结果
  • 1、借助中间结果栈tempStack,【从右至左】扫描表达式
  • 2、遇到操作数时,将操作数入tempStack栈
  • 3、遇到操作符时,从tempStack栈中弹出两个操作数,进行运行,然后将运算结果压入tempStack栈。
  • 4、重复1~3,直到pnStack为空
  • 5、tempStack栈剩下的最后一个元素即所求结果

三、代码实现

代码码云地址:https://gitee.com/w1402943677/self_implementation_tool_class/tree/master/中缀表达式转前缀表达式计算

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值