• page80-栈用例-算术表达式求值


    表达式由括号, 运算符和操作数(数字)组成。我们根据以下4中情况从左到右逐个将这些实体送入栈处理。

    (1)将操作数压入操作数栈;

    (2)将运算符压入运算符栈;

    (3)忽略左括号;

    (4)在遇到右括号时, 弹出一个运算符,弹出所需数量的操作符,并将运算符和操作符的运算结果压入操作数栈。

    【地杰斯特拉的双栈算术表达式求值算法】

    public class Evaluate {
        
        public static void main(String[] args) {
            
            Stack<String> ops = new Stack<String>();
            Stack<Double> vals = new Stack<Double>();
            
            while(!StdIn.isEmpty()){
                
                String s = StdIn.readString();
                if(s.equals("(")) continue;
                else if(s.equals("+")) ops.push(s);
                else if(s.equals("-")) ops.push(s);
                else if(s.equals("*")) ops.push(s);
                else if(s.equals("/")) ops.push(s);
                else if(s.equals("sqrt")) ops.push(s);
                else if(s.equals(")")) {
                    String op = ops.pop();
                    double v = vals.pop();
                    if(op.equals("+")) v = vals.pop() + v;
                    else if(op.equals("-")) v = vals.pop() - v;
                    else if(op.equals("*")) v = vals.pop() * v;
                    else if(op.equals("/")) v = vals.pop() / v;
                    else if(op.equals("sqrt")) v = Math.sqrt(v);
    
                    vals.push(v);
                }//如果字符既非运算符也不是括号,将它作为double值压入栈
                else vals.push(Double.parseDouble(s));
            }
            System.out.println(vals.pop());
        }
    }
  • 相关阅读:
    seajs加载angularjs
    seajs加载jquery提示$ is not a function
    java 动态代理
    C#第三章--对象和类
    Android笔记--两种双击退出程序的方法
    Android--Volley基本用法及自定义
    Win10专业版只要12.99元?应用商店Bug福利也算数
    新人报道
    排序

  • 原文地址:https://www.cnblogs.com/pacoson/p/4004399.html
Copyright © 2020-2023  润新知