[python]将中缀表达式(infix)转换为后缀表达式(postfix)

本文介绍了如何将中缀表达式转换为后缀表达式,包括不含括号的情况和含括号的情况。算法描述了两种情况的处理方式,并给出了具体的Python实现。运行示例展示了转换过程。
摘要由CSDN通过智能技术生成

将中缀表达式(infix)转换为后缀表达式(postfix)

算法描述

  1. 第一种情况,表达式不含括号。

    假设存在一个函数prcd(op1,op2),其中op1和op2是两个操作符(在中缀表达式中,op1在op2的左边),如果op1的优先级高于或等于op2,函数返回True,否则返回False。例如:

    prcd('\*','+') --> True
    
    prcd('+','-') --> True
    
    prcd('\*','/') --> True
    
    prcd('-','*') --> False
    

    考虑表达式 A+B*C。当扫描到A时,将A添加到postfix中,接着遇到‘+’操作符,此时,由于只有一个操作数,‘+’只能先存入栈stack中;当扫描到B时,将其追加至postfix;接着遇到*,栈不为空,那么调用pcdr(pop(stack),’*’),因为‘+’优先级低于‘*’,返回False,将‘*’压入栈中,push(stack,’*’),接着遇到C,将其追加至postfix。这时,表达式扫描完,栈仍不为空,依次pop出数据,追加至postfix。最终结果为‘BC*A+’

  2. 第二种情况,表达式含有括号。

    当扫描到‘(’时,将其压入堆栈,这可以通过使prcd

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值