Java实现计算器的代码

 更新时间:2018年06月17日 13:09:35   作者:Owen-Chan  
这篇文章主要为大家介绍了Java实现计算器的详细代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

用Java实现的计算器,原理看代码注释,具体内容如下

public class MyCalculator {

 public static void main(String[] args) {
 String obj = "6+(8/2)+6/3+1*8 + 30";
 ArrayList<String> arrayList = strFormat(obj);
 System.out.println(obj + "=" + calculator(arrayList));
 }


 /**
 * 采用后续表达式计算结果
 * 1、当前字符串为数字时,直接入栈
 * 2、当前字符串为计算符时,取出栈中的前两个计算
 * 3、将计算结果再放入到栈中,栈中最后剩余的一个元素就是要求的结果
 */
 private static int calculator(ArrayList<String> obj) {
 ArrayList<String> result = transform(obj);
 System.out.println(result);
 Stack<Integer> stack = new Stack<>();

 for (int i = 0; i < result.size(); i++) {
  String symbol = result.get(i);
  if (isDigital(symbol)) { //数字直接入栈
  stack.push(Integer.parseInt(symbol));
  } else { // 处理操作符
  int num1, num2;
  num1 = stack.pop(); //取出两个数
  num2 = stack.pop();
  switch (symbol) {
   case "+":
   stack.push(num2 + num1);
   break;
   case "-":
   stack.push(num2 - num1);
   break;
   case "*":
   stack.push(num2 * num1);
   break;
   case "/":
   stack.push(num2 / num1);
   break;
   default:
   break;
  }
  }
 }
 return stack.pop();
 }

 /**
 * 中序遍历改为后续遍历
 */
 private static ArrayList<String> transform(ArrayList<String> arrayList) {
 Stack<String> stack = new Stack<>();
 ArrayList<String> result = new ArrayList<>();
 for (int index = 0; index < arrayList.size(); index++) {
  String symbol = arrayList.get(index);
  if (isDigital(symbol)) { //如果是数字直接输出
  result.add(symbol);
  } else if (symbol.equals(")")) {
  String tmp;
  while (!(tmp = stack.pop()).equals("(")) { // 匹配成功后停止
   result.add(tmp);
  }
  } else {
  if (stack.isEmpty()) {
   stack.push(symbol);
   continue;
  }
  String tmp = stack.peek();
  while (outPriority(symbol) <= inPriority(tmp)) { //优先级小于栈内优先级,一直出栈
   result.add(tmp);
   stack.pop();
   if (stack.isEmpty()) {
   break;
   }
   tmp = stack.peek();
  }
  stack.push(symbol);
  }
 }
 //将剩余的出栈
 while (!stack.isEmpty()) {
  result.add(stack.pop());
 }
 return result;
 }

 /**
 * 首先对String 进行格式化 转化成ArrayList
 * @param src 3*5+8;
 * @return ArrayList 3 * 5 + 8
 */
 private static ArrayList<String> strFormat(String src) {
 if (src == null || src.equals("")) {
  return null;
 }
 ArrayList<String> arrayList = new ArrayList<>();
 StringBuilder comChar = new StringBuilder();
 for (int i = 0; i <src.length(); i++) {
  char ch = src.charAt(i);
  if (ch == ' ') {
  continue; //去除空格
  }
  if (!Character.isDigit(ch)) {
  if (!comChar.toString().trim().equals("")) {
   arrayList.add(comChar.toString().trim());
   comChar.delete(0, comChar.length());
  }
  arrayList.add(ch + "");
  continue;
  }
  comChar.append(ch);
 }
 if (!comChar.toString().trim().equals("")) {
  arrayList.add(comChar.toString().trim());
 }
 return arrayList;
 }

 /**
 * 判断是否为数字
 * @param symbol 782 或者 + - * /
 * @return true or false
 */
 private static boolean isDigital(String symbol) {
 return !symbol.equals("+") && !symbol.equals("-")
  && !symbol.equals("*") && !symbol.equals("/")
  && !symbol.equals("(") && !symbol.equals(")");
 }

 private static int inPriority(String ch) {
 switch (ch) {
  case "+":
  case "-":
  return 2;
  case "*":
  case "/":
  return 4;
  case ")":
  return 7;
  case "(":
  return 1;
  default:
  return 0;
 }
 }

 private static int outPriority(String ch) {
 switch (ch) {
  case "+":
  case "-":
  return 3;
  case "*":
  case "/":
  return 5;
  case ")":
  return 1;
  case "(":
  return 7;
  default:
  return 0;
 }
 }
}

以上全部为本篇文章的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 解决Springboot不能自动提交数据库连接问题

    解决Springboot不能自动提交数据库连接问题

    在使用SSM框架开发时,若在同一Service内部方法间互相调用,直接使用this关键字会导致事务管理失效,从而引发如数据库连接不足等问题,原因是通过this调用不会经过Spring的代理,因此不会自动进行事务处理
    2024-09-09
  • Spring Boot 集成Redisson实现分布式锁详细案例

    Spring Boot 集成Redisson实现分布式锁详细案例

    这篇文章主要介绍了Spring Boot 集成Redisson实现分布式锁详细案例,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
    2022-08-08
  • JAVA如何把数据库的数据处理成树形结构

    JAVA如何把数据库的数据处理成树形结构

    本文介绍了JAVA如何把数据库的数据处理成树形结构,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • java底层JDK Logging日志模块处理细节深入分析

    java底层JDK Logging日志模块处理细节深入分析

    这篇文章主要为大家介绍了java底层JDK Logging日志模块处理细节深入分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • maven插件maven-jar-plugin构建jar文件的详细使用

    maven插件maven-jar-plugin构建jar文件的详细使用

    maven-jar-plugin插件时maven中最常用的插件,也是maven构建Java程序执行包或者依赖包的默认插件,本文主要介绍了maven插件maven-jar-plugin构建jar文件的详细使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • SpringBoot3实现Gzip压缩优化的技术指南

    SpringBoot3实现Gzip压缩优化的技术指南

    随着 Web 应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用 Gzip 压缩 HTTP 响应,本文将介绍如何在 Spring Boot 3 中实现 Gzip 压缩优化,需要的朋友可以参考下
    2025-04-04
  • 使用Mock进行业务逻辑层Service测试详解

    使用Mock进行业务逻辑层Service测试详解

    这篇文章主要介绍了使用Mock进行业务逻辑层Service测试详解,mock是一种模拟对象的技术,用于在测试过程中替代真实的对象,通过mock,我们可以控制被模拟对象的行为和返回值,以便进行更加精确的测试,需要的朋友可以参考下
    2023-08-08
  • Java Spring Security认证与授权及注销和权限控制篇综合解析

    Java Spring Security认证与授权及注销和权限控制篇综合解析

    Spring Security 是 Spring 家族中的一个安全管理框架,实际上,在 Spring Boot 出现之前,Spring Security 就已经发展了多年了,但是使用的并不多,安全管理这个领域,一直是 Shiro 的天下
    2021-10-10
  • Java8如何从一个Stream中过滤null值

    Java8如何从一个Stream中过滤null值

    这篇文章主要介绍了Java8如何从一个Stream中过滤null值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • java实现微信扫码支付功能

    java实现微信扫码支付功能

    这篇文章主要为大家详细介绍了java实现微信扫码支付功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07

最新评论