public class Counter {

/**用递归算法,把括号内的公式算出然后递归
  * @param args
  */

public static void calculator (String str){
  //System.out.println(str);
  //装载到StringBuffer提升效率
  StringBuffer cstr= new StringBuffer(str);
  //用正则把算式内的剩除符号和数字分组,
  Pattern p=Pattern.compile("\\-?[0-9]+(\\.[0-9]+)?|[*/]");
  if(cstr.length()==0)System.out.println("请输入计算式");
  //找出最后一个括号的坐标
  int start=cstr.lastIndexOf("(");
  //叛断公式是否还有括号
  if(start!=-1){
  int end=cstr.indexOf(")",start);
  StringBuffer spstr=new StringBuffer( cstr.subSequence(start+1, end));
  //删去截去的括号内的基本公式
       cstr=cstr.delete(start, end+1);
       //正则匹配
       Matcher m =p.matcher(spstr);
      List numlist=new ArrayList();
      //把基本公式的值和乘除符号加入到给组
      while(m.find()){
       numlist.add(m.group());
      }
      //调用计算方法并返回结果
      StringBuffer str1=count(numlist);
      //把结果INSERT到指定位置
      cstr=cstr.insert(start, str1);
  }else{
   //最后一次无括号计算基本公式并打印最终结果
   Matcher m =p.matcher(cstr);
   List numlist=new ArrayList();
   while(m.find()){
      numlist.add(m.group());
   }
   StringBuffer str1=count(numlist);
   System.out.println(str1);
   return;
  }
     //递归数组
 // System.out.println(cstr);
  calculator(new String(cstr));
 }

/**
 *
 * @param list  接收基本公式数组
 * @return 返回计算结果字符串
 */
 private static StringBuffer count(List list){
 // System.out.println(list);
  double num = 0;
  for (int i = 0; i < list.size(); i++) {
   if(list.get(i).equals("*")||list.get(i).equals("/")){
   Double  d=list.get(i).equals("*")?Double.parseDouble((String) list.get(i-1))*Double.parseDouble((String) list.get(i+1)):Double.parseDouble((String) list.get(i-1))/Double.parseDouble((String) list.get(i+1));
    list.add(i-1, d+"");list.remove(i);list.remove(i);list.remove(i);
    i=i-1; 
   
   }
  }
  
 for (int i = 0; i < list.size(); i++) {
   num+=Double.parseDouble((String) list.get(i));
  }

return  new StringBuffer(num+"");
 
 }
 
 
 public static void main(String[] args) {
  
  calculator("3+2+((5-6)*(-3+3/2)/2)");

}

}

java 四则混合运算 计算器的更多相关文章

  1. 用C++实现的有理数(分数)四则混合运算计算器

    实现目标 用C++实现下图所示的一个console程序: 其中: 1.加减乘除四种运算符号分别用+.-.*./表示, + 和 - 还分别用于表示正号和负号. 2.分数的分子和分母以符号 / 分隔. 3 ...

  2. 如何处理加括号的四则混合运算表达式——基于二叉树的实现(Eclipse平台 Java版)

    记得上<数据结构>课程时,利用栈的特性解决过四则混合运算表达式.而如今在编写小型关系数据库的时候,编译部分要处理where后面的逻辑表达式——检查语法正确与否的同时,还要将信息传给下一个接 ...

  3. java 解析四则混合运算表达式并计算结果

    package ch8; import java.util.LinkedList; import java.util.List; import java.util.Stack; /** * 四则混合运 ...

  4. 软件工程学习之小学四则混合运算出题软件 Version 1.00 设计思路及感想

    对于小学四则混合运算出题软件的设计,通过分析设计要求,我觉得为了这个软件在今后便于功能上的扩充,可以利用上学期所学习的<编译原理>一课中的LL1语法分析及制导翻译的算法来实现.这样做的好处 ...

  5. MathExamV2.0四则混合运算计算题生成器

    MathExamV2.0四则混合运算计算题生成器----211606360 丁培晖 211606343 杨宇潇 一.预估与实际 PSP2.1 Personal Software Process Sta ...

  6. C语言编程学习:写的秒速计算四则混合运算项目

    C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构.C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现 ...

  7. 数据结构之栈—强大的四则复杂运算计算器(超过windows自带的科学计算器)【中缀转后缀表达式】

    比windows自带计算器还强的四则复杂运算计算器! 实测随机打出两组复杂算式:-7.5 * 6 / ( -2 + ( -6.5 -  -5.22 ) )与7.5+-3*8/(7+2) windows ...

  8. 软件工程学习之小学四则混合运算出题软件 Version 1.1 设计思路及感想

    继上次采用形式文法来生成混合运算的算式,由于算法中没有引入控制参数而导致容易产生形式累赘(多余的括号等)的算式.本次更新决定采用一种更为简单有效的生成方式,由给出的一个随机的最终答案S,通过给定的一个 ...

  9. 带括号的四则混合运算的算符优先算法-----java实现

    1:主方法 package com.baidu; import java.text.NumberFormat;import java.util.ArrayList;import java.util.S ...

随机推荐

  1. STM32F412应用开发笔记之八:迪文串口屏显示驱动

    迪文的显示屏使用起来比较方便,其使用串口通讯,即可支持RS232,又可以支持TTL电平.在NUCLEO-F412ZG实验板上,USART2已经引到了CN9上,我们就利用USART2来实现与迪文串口屏的 ...

  2. VB.Net隐式转换和显式转换的方法(转)

    VB.Net隐式转换和显式转换的方法(转) “隐式转换”不需要源代码中的任何特殊语法.在下面的示例中,在将 k 的值赋给 q 之前,Visual Basic 将该值隐式转换成单精度浮点值.   Dim ...

  3. make的参数

    转载自 陈皓<跟我一起写 Makefile> 下面列举了所有GNU make 3.80版的参数定义.其它版本和产商的make大同小异,不过其它产商的make的具体参数还是请参考各自的产品文 ...

  4. DrawerLayout学习笔记

    基本步骤: 1>在XML中将DrawerLayout作为根视图 2>根视图中放两个View,第一个是主视图,即DrawerLayout隐藏的时候的视图,第二是就DrawerLayout的视 ...

  5. html 上传文件

    1.html代码 <form id="form1" action="TestYield" method="post" enctype= ...

  6. C#中的协变OUT和逆变

    泛型接口和泛型委托中经常使用可变性 in  逆变,out  协变 从 list<string>转到list<object> 称为协变 (string 从object 派生,那么 ...

  7. UVa 594 - One Little, Two Little, Three Little Endians

    题目大意:大小端模式的转换.所谓的小端模式,是指数据的高位保存在内存的高地址中,而数据的低位保存在内存的低地址中.与此相对,所谓的大端模式,是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内 ...

  8. Subpub 订阅/发布

    var Pubsub = (function (window) { window.handlers = {}; var o = { pub: function () { var args = Arra ...

  9. jquery proxy

    slice = Array.prototype.slice,// Bind a function to a context, optionally partially applying any // ...

  10. 利用DIV+CSS制作网页过程中常用的基本概念及标签使用细节

    CSS主要用于对HTML文件功能的补充及扩展,其作用就是对HTML文件中各种排版进行设置,达到对网页中字体.颜色.背景.图片等的控制,使网页能够完全依照设计者的想法来显示. CSS可以控制网页的显示, ...