中缀转后缀表达式——java(附四则运算)

本文介绍了如何使用Java将中缀表达式转换为后缀表达式(逆波兰表达式)。通过建立符号栈和结果队列,遍历表达式,遇到数字直接入队,遇到符号则根据优先级规则决定入栈或入队,最终得到后缀表达式。详细思路及粗糙的代码实现附带。
摘要由CSDN通过智能技术生成

1. 后缀表达式

后缀表达式,即为逆波兰表达式,其运算方法为从左到右扫描表达式,当遇到符号时,取该符号前两位数,使用前一个数运算后一个数,将结果放入刚才两个数的位置,运算的两个数以及符号便去掉。由此得知,使用栈运算会很方便,下面会有完整的计算一个四则运算表达式的代码

2. 思路分析

1.将字符串转化为list,目的是方便操作
2.简历一个符号栈与结果队列,符号栈用于存储遍历得到的符号,队列利用其先进先出的特性来记录转化后的后缀表达式
3.遍历该list
3.1该元素为数字,直接入结果队列
3.2该元素为符号
3.2.1栈为空或者栈顶元素为”(“,则将该元素直接入符号栈
3.2.2栈顶元素优先级小于该元素,则将该元素直接入符号栈
3.2.3如果不满足以上条件,则将栈顶元素入结果队列,并且从3.2.1继续开始进行判断
3.3遍历list结束后,将栈中剩余的元素依次加入结果队列中,结果即为对应的后缀表达式

3. 代码实现

//本代码包含: 中缀表达式转化后缀表达式,计算后缀表达式
package stack;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Stack;

/**
 * 逆波兰计算器
 */
public class ReversePolish {
   

    public static void main(String[] args) {
   
        String s = "2*(16+8/4-5)+4";
        ReversePolish reversePolish = new ReversePolish();
        System.out.println(reversePolish.toReversePolish(stringToList(s)).toString());
        System.out.println(reversePolish.calculate(reversePolish.toReversePolish(stringToList(s))));
    }

    private List<String> toReversePolish(List<String> list){
   
        Stack<String> stack = new Stack<String>();
        List<String> linkedList = new LinkedList<String>();
        for (int i = 0; i < list.size(); i++){
   
            String s = list.get(i);
            int chk = check(s);
            //如果当前元素为符号<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值