`

计算表达式算法

 
阅读更多
import java.util.ArrayList;
import java.util.Stack;
 
 
public class PostfixExp {
  
   public static void main(String[] args) {
      PostfixExp pExp = new PostfixExp();
     
      //String exp = "a + b*c + (d * e + f) * g";
      //string exp = "1+1+3*2*3-4";
      //string exp = "2+(1+3)*2*3-4";
      //string exp = "2+1+3*2*(3-4)";
      String exp = "(13+10/2)*21*(39-4)";
      String case1 = "(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))";
      String case2 = "(6*7+9+8/2*12+12/3)+88/11";
      String case3 = "(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))";
      String case4 = "(6*7+9+8/2*12+12/3)+((88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))";
      String case5 = "(6*7+9+8/2*12+12/3)+((88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))+(6*7+9+8/2*12+12/3)+((88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))";
      String case6 = "(3*(4+9)+8/(2*12)+12/3)+(((7+(13+10/2))*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))+(6*7+9+8/2*12+12/3)+((88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))";
 
      ArrayList<String> expList = pExp.change2PostfixExp(case6);
      for(String item : expList) {
         System.out.print(item + " ");
      }
      System.out.println("\n");
      System.out.println("My answer is \t\t" + pExp.calculate(expList));
     
      int rightAnswer = (3*(4+9)+8/(2*12)+12/3)+(((7+(13+10/2))*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))))+(6*7+9+8/2*12+12/3)+((88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4)))+(6*7+9+8/2*12+12/3)+(88/11+(13+10/2)*(21*(39-4)+(13+10/2)*21*(39-4))));
      System.out.println("The right answer is \t" + rightAnswer);
     
      System.out.println();
   }
  
   private Stack<String> opStack;
   private Stack<String> expStack;
   private String[] ops = {"+", "-", "*", "/", "(", ")", "#"};
  
   public PostfixExp() {
      opStack = new Stack<String>();
      expStack = new Stack<String>();
   }
  
   private boolean isOp(char c) {
      String cStr = Character.toString(c);
     
      for (String op : ops) {
         if(cStr.equals(op)) {
            return true;
         }
      }
     
      return false;
   }
  
   private boolean isOp(String str) {
      for(String op : ops) {
         if(str.equals(op)) {
            return true;
         }
      }
     
      return false;
   }
  
   private int getOpPriority(String op){
      if("+".equals(op) || "-".equals(op)) {
         return 1;
      }
      else if("*".equals(op) || "/".equals(op)) {
         return 2;
      }
      else if("(".equals(op)) {
         return 3;
      }
      else if("#".equals(op)) {
         return 0;
      }
     
      return Integer.MAX_VALUE;
   }
  
   public String[] getItems(String str) {
      ArrayList<String> list = new ArrayList<String>();
     
      // Remove all blank spaces.
      str = str.replaceAll("\\s", "");
     
      int i = 0;
      StringBuilder sBuilder = new StringBuilder();
      while(i < str.length()) {
         if(i == str.length() - 1) {
            sBuilder.append(
                   Character.toString(str.charAt(i)));
            list.add(sBuilder.toString());
         }
        
         if(!isOp(str.charAt(i))) {
            sBuilder.append(
                Character.toString(str.charAt(i)));
           
         }
         else {
            if(sBuilder.length() > 0) {
                list.add(sBuilder.toString());
                sBuilder.delete(0, sBuilder.length());
            }
            list.add(Character.toString(str.charAt(i)));
         }
        
         ++i;
      }
 
      list.add("#");
 
      String[] result = new String[list.size()];
      return list.toArray(result);
   }
  
   public ArrayList<String> change2PostfixExp(String normalExp) {
      ArrayList<String> expList = new ArrayList<String>();
      String[] items = getItems(normalExp);
     
      opStack.clear();
      expStack.clear();
     
      opStack.push("#");
     
      int i = 0;
      while(i < items.length) {
         //System.out.println(i + ":" + items[i]);
         if(!isOp(items[i])) {
            expList.add(items[i]);
         }
         else {
            if(items[i].equals(")")){
                while(!opStack.isEmpty() && !opStack.peek().equals("(")) {
                   expList.add(opStack.pop());
                }
               
                if(!opStack.isEmpty() && opStack.peek().equals("(")) {
                   opStack.pop();
                }
                ++i;
                continue;
            }
           
            if(items[i].equals("#")) {
                while(!opStack.isEmpty() && !opStack.peek().equals("#")) {
                   expList.add(opStack.pop());
                }
                break;
            }
           
            if(!opStack.isEmpty()) {
                while(!opStack.isEmpty()
                      && (getOpPriority(opStack.peek()) >= getOpPriority(items[i])
                      && !opStack.peek().equals("("))
                ) {
                   expList.add(opStack.pop());
                }
                opStack.push(items[i]);
            }
         }
        
         ++i;
      }
     
      return expList;
   }
  
   public double calculate(ArrayList<String> postfixExp) {
      Stack<Double> calcStack = new Stack<Double>();
     
      int i = 0;
      String ite = null;
      double result = Double.MAX_VALUE;
     
      while(i < postfixExp.size()) {
         ite = postfixExp.get(i);
         if(!isOp(postfixExp.get(i))) {
            calcStack.push(new Double(
                         Double.parseDouble(
                               postfixExp.get(i))
            ));
         }
         else {
            double num2 = calcStack.peek();
            calcStack.pop();
            if(!calcStack.isEmpty()) {
                double num1 = calcStack.peek();
                calcStack.pop();
               
                if("*".equals(ite)) {
                   result = num1 * num2;
                }
                else if("+".equals(ite)) {
                   result = num1 + num2;
                }
                else if("-".equals(ite)) {
                   result = num1 - num2;
                }
                else if("/".equals(ite)) {
                   result = num1 / num2;
                }
                System.out.println(num1 + "\t" + ite + "\t" + num2 + " = " + result);
                calcStack.push(result);
            }
         }
         ++i;
      }
     
      return result;
   }
}

 

 

分享到:
评论

相关推荐

    表达式计算算法(CPP)

    使用后缀表达式来实现表达式的计算。使用堆栈,把中缀表达式转换为后缀,支持运算符优先级。

    易语言脚本计算表达式

    在易语言中,脚本计算表达式是编程过程中的一个重要环节,它涉及到变量、运算符、函数和控制结构等多个方面。 易语言脚本计算表达式源码是指使用易语言编写的,能够解析并执行计算表达式的代码。这种源码通常包含...

    中缀表达式转化为后缀表达式算法及后缀表达式算法的实现.doc

    中缀表达式转化为后缀表达式算法及后缀表达式算法的实现 中缀表达式转化为后缀表达式算法是计算机科学中的一种常见算法,用于将中缀表达式转化为后缀表达式。该算法广泛应用于编译器、解释器、计算器等领域。 中缀...

    二叉树算法计算表达式

    二叉树计算表达式 行之有效的代码,完全可以上交老师那种!

    ^计算表达式的算法^

    本主题主要关注如何使用C++实现一个计算表达式的算法。C++是一种强大且广泛应用的面向对象的编程语言,它提供了丰富的工具来处理这种问题。 首先,计算表达式通常涉及到解析、求值两个主要步骤。解析是将输入的字符...

    易语言逻辑表达式算法编译原理

    逻辑表达式算法编译原理,是否汉字,读字符,是否运算符,是否逻辑运算符,指针回溯,跳过空格,跳过注释,外部接口_表达式计算,表达式计算,逻辑判断,函数调用,函数_位或,函数_测试,计算表达式数组,单个计算,输出状态

    中缀表达式转化为后缀表达式算法及后缀表达式计算算法.doc.doc

    中缀表达式转化为后缀表达式算法及后缀表达式计算算法.doc.doc

    两种方式计算表达式(C语言)

    中缀表达式转换为后缀表达式算法 该算法的核心思想是将中缀表达式转换为后缀表达式,然后通过后缀表达式计算出算术表达式的结果。该算法的步骤如下: 1. 定义一个 Node 结构体,结构体内部包含四个属性:操作符的...

    逆波兰表达式算法_表达式_

    总之,逆波兰表达式算法提供了一种简洁、高效的方式来计算数学表达式,其核心在于使用栈数据结构和运算符优先级规则。在`ExpressionParserUtil.java`文件中,我们可以找到具体的实现细节,这为我们理解和扩展该算法...

    易语言计算表达式速度对比

    在易语言中,计算表达式是程序逻辑的重要组成部分,用于执行各种数学和逻辑运算。本文将深入探讨易语言中的计算表达式,以及其在不同场景下的速度对比。 首先,我们要理解计算表达式的概念。在易语言中,计算表达式...

    表达式算法使用了树结构

    树结构在计算表达式时具有显著优势,因为它们直观地反映了运算符的优先级和嵌套关系,使得计算过程更为简洁和高效。 首先,让我们深入理解什么是树结构。树是一种非线性的数据结构,由顶点(也称为节点)和连接这些...

    数据结构计算表达式的值

    本实验主题“数据结构计算表达式的值”着重于使用堆栈这一特殊的数据结构来解析和计算数学表达式。堆栈是一种后进先出(LIFO)的数据结构,非常适合解决逆波兰表示法(RPN,Reverse Polish Notation)或后缀表达式的...

    基于C++开发的,可以计算算术逻辑表达式的算法工程

    在本项目中,我们主要探讨的是一个基于C++编程语言实现的算术逻辑表达式计算算法。这个工程是在Visual Studio 2010环境下构建的,因此,它充分考虑了与该IDE的兼容性,使得开发者能够直接在VS2010中打开、编译并运行...

    算术表达式运算算法

    在编程实现中,我们可以使用递归下降解析(Recursive Descent Parsing)或基于栈的算法(如Shunting-yard算法)将中缀表达式转换为后缀表达式,然后用栈来计算结果。Shunting-yard算法由Dijkstra提出,它首先将输入...

    堆栈实现后缀表达式算法

    在这个堆栈实现后缀表达式算法的项目中,我们将在WinForm平台上构建一个能够处理这种表达式的计算器。 在后缀表达式中,运算符位于其操作数之后。例如,常规的乘法表达式 "2 * 3" 在后缀表达式中会写成 "2 3 *"。...

    正则表达式匹配算法

    1. 避免重复计算:对于相同的正则表达式,我们可以通过预编译构造出NFA,避免重复解析。 2. 避免回溯:利用NFA的特性,避免在处理量词时回溯。 3. 使用KMP或Boyer-Moore等高级字符串搜索算法,提高字符串匹配的效率...

    sthg.rar_计算表达式值

    计算表达式值是一个涉及到字符串处理、语法分析和算法设计的复杂问题。在实际编程中,我们需要考虑各种情况,例如错误处理(如非法字符、缺少括号等)、数值溢出以及用户界面设计等。后缀表达式的方法虽然更高效,但...

    二叉树应用——计算表达式[参照].pdf

    二叉树应用——计算表达式计算 二叉树是一种常用的数据结构,它可以用于表示复杂的计算表达式。二叉树的结构由节点组成,每个节点都可以有左右两个子节点。这种数据结构可以用于计算复杂的表达式,因为它可以将...

    正则表达式匹配算法小结

    多字符串匹配算法(MultiStringRE)需要计算所有长度为l_min的前缀集合Pref(RE)。该算法类似于Commentz-Walter算法,只需要从Pref(RE)在文本中的初始位置开始验证RE是否匹配成功即可。 ##### Gnu的基于必要因子的...

    算符优先分析器与计算表达式的值

    这个技术基于算符优先关系来构建语法分析树,从而有效地计算表达式的值。算符优先分析通常涉及到编译器设计和实现,是计算机科学中的核心概念之一。 标题中的“算符优先分析器”是指一种解析技术,它根据算符的...

Global site tag (gtag.js) - Google Analytics