zoukankan      html  css  js  c++  java
  • 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());
        }
    }
  • 相关阅读:
    .NET 开源框架
    ORM 开发框架
    C# 文件下载四方法
    用ASP.net判断上传文件类型的三种方法
    站在十字路口的程序媛,该如何选择?
    突然的烦恼
    Request获取url信息的各种方法比较 及 Request.UrlReferrer详解
    JS 获得当前地址栏url
    MvcPager 概述
    Simditor使用方法
  • 原文地址:https://www.cnblogs.com/pacoson/p/4004399.html
Copyright © 2011-2022 走看看