欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)計(jì)算器的代碼

 更新時(shí)間:2018年06月17日 13:09:35   作者:Owen-Chan  
這篇文章主要為大家介紹了Java實(shí)現(xiàn)計(jì)算器的詳細(xì)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

用Java實(shí)現(xiàn)的計(jì)算器,原理看代碼注釋,具體內(nèi)容如下

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


 /**
 * 采用后續(xù)表達(dá)式計(jì)算結(jié)果
 * 1、當(dāng)前字符串為數(shù)字時(shí),直接入棧
 * 2、當(dāng)前字符串為計(jì)算符時(shí),取出棧中的前兩個(gè)計(jì)算
 * 3、將計(jì)算結(jié)果再放入到棧中,棧中最后剩余的一個(gè)元素就是要求的結(jié)果
 */
 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)) { //數(shù)字直接入棧
  stack.push(Integer.parseInt(symbol));
  } else { // 處理操作符
  int num1, num2;
  num1 = stack.pop(); //取出兩個(gè)數(shù)
  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();
 }

 /**
 * 中序遍歷改為后續(xù)遍歷
 */
 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)) { //如果是數(shù)字直接輸出
  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)) { //優(yōu)先級(jí)小于棧內(nèi)優(yōu)先級(jí),一直出棧
   result.add(tmp);
   stack.pop();
   if (stack.isEmpty()) {
   break;
   }
   tmp = stack.peek();
  }
  stack.push(symbol);
  }
 }
 //將剩余的出棧
 while (!stack.isEmpty()) {
  result.add(stack.pop());
 }
 return result;
 }

 /**
 * 首先對(duì)String 進(jìn)行格式化 轉(zhuǎn)化成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;
 }

 /**
 * 判斷是否為數(shù)字
 * @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;
 }
 }
}

以上全部為本篇文章的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java 處理超大數(shù)類型之BigInteger案例詳解

    Java 處理超大數(shù)類型之BigInteger案例詳解

    這篇文章主要介紹了Java 處理超大數(shù)類型之BigInteger案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Intellij IDEA如何設(shè)置代理

    Intellij IDEA如何設(shè)置代理

    這篇文章主要介紹了Intellij IDEA如何設(shè)置代理問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Java語(yǔ)言描述MD5加密工具類實(shí)例代碼

    Java語(yǔ)言描述MD5加密工具類實(shí)例代碼

    這篇文章主要介紹了Java語(yǔ)言描述MD5加密工具類實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • Java中創(chuàng)建線程的四種方法解析

    Java中創(chuàng)建線程的四種方法解析

    這篇文章主要介紹了Java中創(chuàng)建線程的四種方法解析,線程是Java編程語(yǔ)言中的一個(gè)重要概念,它允許程序在同一時(shí)間執(zhí)行多個(gè)任務(wù),線程是程序中的執(zhí)行路徑,可以同時(shí)執(zhí)行多個(gè)線程,每個(gè)線程都有自己的執(zhí)行流程,需要的朋友可以參考下
    2023-10-10
  • Java中的LinkedHashSet解析

    Java中的LinkedHashSet解析

    這篇文章主要介紹了Java中的LinkedHashSet解析,與HashSet不同的是,LinkedHashSet在內(nèi)部使用了一個(gè)雙向鏈表來(lái)維護(hù)元素的順序,因此它可以保持元素的插入順序,這使得LinkedHashSet在需要保持元素順序的場(chǎng)景下非常有用,需要的朋友可以參考下
    2023-11-11
  • JSON.parseObject和JSON.toJSONString實(shí)例詳解

    JSON.parseObject和JSON.toJSONString實(shí)例詳解

    這篇文章主要為大家詳細(xì)介紹了JSON.parseObject和JSON.toJSONString實(shí)例,具有一定的參考價(jià)值,感興趣的朋友可以參考一下
    2018-06-06
  • springboot打war包的全過(guò)程記錄

    springboot打war包的全過(guò)程記錄

    其實(shí)一般使用springboot使用打成jar包比較省事的,但也有很多童鞋是習(xí)慣使用war包的,下面這篇文章主要給大家介紹了關(guān)于springboot打war包的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • idea創(chuàng)建SpringBoot自動(dòng)創(chuàng)建Lombok無(wú)效果的問(wèn)題解決方案

    idea創(chuàng)建SpringBoot自動(dòng)創(chuàng)建Lombok無(wú)效果的問(wèn)題解決方案

    這篇文章主要介紹了idea創(chuàng)建SpringBoot自動(dòng)創(chuàng)建Lombok無(wú)效果的問(wèn)題解決方案,感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • vue+springboot前后端分離工程跨域問(wèn)題解決方案解析

    vue+springboot前后端分離工程跨域問(wèn)題解決方案解析

    這篇文章主要介紹了vue+springboot前后端分離工程跨域問(wèn)題解決方案解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示功能(詳細(xì)步驟)

    SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示功能(詳細(xì)步驟)

    這篇文章主要介紹了SpringBoot整合Echarts實(shí)現(xiàn)用戶人數(shù)和性別展示,通過(guò)數(shù)據(jù)庫(kù)設(shè)計(jì)、實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)層、業(yè)務(wù)邏輯層和控制層的代碼編寫,以及前端頁(yè)面的開(kāi)發(fā),本文詳細(xì)地介紹了SpringBoot整合Echarts的實(shí)現(xiàn)步驟和代碼,需要的朋友可以參考下
    2023-05-05

最新評(píng)論