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;
  }
 }
}

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

(0)

相关推荐

  • 使用jsp调用javabean实现超简单网页计算器示例

    以下是代码: Calculator.java 复制代码 代码如下: package com.amos.model; import java.math.BigDecimal; /** * @ClassName: Calculator * @Description: 计算器 * @author: amosli * @email:amosli@infomorrow.com * @date Mar 20, 2014 1:04:59 AM  */ public class Calculator {    

  • java模仿windows计算器示例

    这个计算器的界面模仿Windows自带的简易计算器,包括交互界面和和对各种输入的响应.目前尚未实现菜单栏和记忆类按钮的功能 复制代码 代码如下: import java.awt.Color;import java.awt.Container;import java.awt.GridLayout;import java.awt.Insets;import java.awt.event.ActionEvent;import java.awt.event.ActionListener; import

  • 逆波兰计算器(Java实现)

    之前的一篇博客中,讲的是用栈实现了中缀表达式的简易计算器,对于我们人来讲,中缀表达式是一种比较直观,而且非常好计算的一种形式,但对于计算器来讲,非常的难去看懂.所以,下面我讲下逆波兰计算器的Java实现. 逆波兰式(后缀表达式) 逆波兰表达式又叫做后缀表达式.逆波兰表示法是波兰逻辑学家J・卢卡西维兹(J・ Lukasewicz)于1929年首先提出的一种表达式的表示方法 [1]  .后来,人们就把用这种表示法写出的表达式称作"逆波兰表达式".逆波兰表达式把运算量写在前面,把算符写在后面

  • java图形界面AWT编写计算器

    一.前言 1)这个计算器是基于java语言下图形界面AWT编写的.其实我认为写这个计算器,实现什么功能不重要,市场也不缺这个计算器,而是在于对AWT中三大布局的及画板的使用简单控件的操作使用.通过联系熟悉掌握AWT基础为深入学习打下基础.这个计算器功能也十分简单,空有其表.不过有兴趣的话可以继续添加功能完善操作等. 2)使用平台:主要使用Myeclipse2014 3)主要知识点:java 基础; awt+swing 二.功能实现及代码展示 1)主要是layout布局的练习,对画板文本框的使用,

  • Java简易计算器程序设计

    编写一个模拟计算器的应用程序,使用面板和网格布局, 添加一个文本框,10个数字按钮(0~9),4个加减乘除按钮, 一个等号按钮,一个清除按钮,一个求平方根按钮,一个退格按钮, 要求将计算公式和结果显示在文本框中,实现效果如下图所示. Java简易计算器代码: import javax.swing.*; import javax.swing.JTextField; import java.awt.*; import java.awt.event.*; import java.lang.*; imp

  • java 简单的计算器程序实例代码

    java 简单的计算器程序 实现实例: import java.awt.*; import java.awt.event.*; import javax.swing.*; public class Calculator { public static void main(String[] args) { EventQueue.invokeLater(new Runnable() { public void run() { CalculatorFrame frame = new Calculato

  • java实现简易计算器功能

    本文为大家分享了java实现简易计算器功能,具体内容如下 题目: 编写一个模拟计算器的程序.在面板中添加一个文本框(显示按键及运算结果). 10个数字按钮(0~9).4个运算按钮(加.减.乘.除).一个等号按钮.一个清除按钮, 要求将按键和结果显示在文本框中. 代码过程展示: import java.awt.Container; import java.awt.FlowLayout; import java.awt.GridLayout; import java.awt.event.Action

  • java实现简单的计算器类实例

    本文实例讲述了java实现简单的计算器类.分享给大家供大家参考.具体如下: package chap; import java.awt.BorderLayout; import java.awt.Color; import java.awt.FlowLayout; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.text

  • Java swing实现的计算器功能完整实例

    本文实例讲述了Java swing实现的计算器功能.分享给大家供大家参考,具体如下: package awtDemo; import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.util.Vector; public class Calculator { String str1 = "0"; // 运算数1 初值一定为0 为了程序的安全 String str2 = "0"

  • java按钮控件数组实现计算器界面示例分享

    思路如下: 创建一个类,通过extends使其继承窗体类JFrame:创建一个JFrame对象,使用JFrame类的setVisible()方法设置窗体可见:在构造函数中,使用super()方法继承父类的构造方法:使用setTitle()方法设置窗体的标题:使用setBounds()方法设置窗体的显示位置及大小:使用setDefaultCloseOperation()方法设置窗体关闭按钮的动作为退出:使用GridLayout创建网格布局管理器对象:使用GridLayout类的setHgap()方

随机推荐