Stack:后缀表达式计算

import java.util.ArrayList;import java.util.List;import java.util.Stack;public class PolandNotation { public static void main(String[] args) { //先定义逆波兰表达式 //(3+4)*5 -6 => 3 4 + 5 * 6 - // 4 *5 - 8 + 60 + 8 /2 -->.
摘要由CSDN通过智能技术生成

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

public class PolandNotation {
   
    public static void main(String[] args) {
   

        //先定义逆波兰表达式
        //(3+4)*5 -6  => 3 4 + 5 * 6 -


        // 4 *5 - 8 + 60 + 8 /2  -->  4 5 * 8 - 60 + 8 2 / +

        //为了方便,逆波兰表达式 的数字和符号使用空格隔开
        String suffixExpression = "3 4 + 5 * 6 -";
        //思路
        //1. 先将 suffixExpression 放到一个ArrayList中
        //2. 将ArrayList 传递给一个方法,遍历 ArrayList 配合栈完成计算

        List<String> list = getListString(suffixExpression);
        System.out.println(list);

        System.out.println("计算结果是: "+calculate(list));
        System.out.println("计算结果是: "+calculate(getListString("4 5 * 8 - 60 + 8 2 / +")));

    }

    //将一个逆波兰表达式,依次将数据和运算符 放入到ArrayList中
    public static List<String> getListString(String suffixExpression) {
   
        //将 suffixExpression分割
        String[] s = suffixExpression.split(" ");
        List<String> list = new ArrayList<String>();
        for (String ele : s) {
   
            list.add(ele);
        }
        return list;
    }

    //完成对逆波兰表达式的运算

    /**
     * 1.从左至右扫描,将3和4压入堆栈
     * 2.遇到+运算符,弹出3和4,并计算其值,再将结果入栈
     * 3.将5入栈
     * 4.遇到 * 运算符, 弹出 5 和 7 , 计算,入栈
     * 5. 将 6 入栈
     * 6.最后遇到 - 运算符, 计算出35-6的值,入栈,最后结果
     */
    public static int calculate(List<String> ls) {
   
        // 创建栈, 只需要一个栈即可
        Stack<String> stack = new Stack
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值