麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Java > 正文

Java計算器核心算法代碼實現

2024-07-14 08:43:25
字體:
來源:轉載
供稿:網友

在進行一個表達式的計算時,先將表達式分割成數字和字符串然后利用出入棧將分割后的表達式進行中綴轉后綴,再將后綴表達式進行計算得到結果(思想在上一篇寫過)現在貼下Java語言的代碼實現。(學習Java時間不長所以可能會有很多不足的地方,我會改進也歡迎大神可以給我一些意見和建議~謝謝啦)

我將這部分分成三個方法完成功能,并在getResult方法調用(getResult方法被主方法調用)

private String getResult(String str) {    //分割    String[] Str = segment(str);    //中綴轉后綴    String newStr = infToSuf(Str);    //后綴計算    String result = sufToRes(newStr);    return sufToRes(result);  }

1.字符串分割,為避免在TextView上顯示帶空格刪除時不方便而且顯示屏就那么大占地方,錄入時的字符串中沒有空格然后就手動分割了

private static String[] segment(String str) {    String[] exp = new String[str.length()+1];    //找最近的索引并截取字符串    int l = str.length();    for(int i = 0;i < l+1;i++) {      int index;      int[] ind = new int[6];      ind[0] = str.indexOf('+');      ind[1] = str.indexOf('-');      ind[2] = str.indexOf('*');      ind[3] = str.indexOf('/');      ind[4] = str.indexOf('(');      ind[5] = str.indexOf(')');      if(ind[1] == 0) {        Arrays.sort(ind);        int t;        for(t = 0;t <6;t++) {          if(ind[t] >= 0)            break;        }        int r = ind[t+1];        exp[i] = str.substring(0,r);        i++;        exp[i] = str.substring(r,r+1);        str = str.substring(r+1);      }else if(((ind[1]-ind[4]) == 1) && (ind[4]==0)) {        Arrays.sort(ind);        int t ;        for(t = 0;t <6;t++) {          if(ind[t] >= 0)            break;        }        int r = ind[t+1];        exp[i] = str.substring(0,1);        i++;        exp[i] = str.substring(1,r+2);        i++;        exp[i] = str.substring(r+2,r+3);        str = str.substring(r+3);      }else {        Arrays.sort(ind);        int t;        for(t = 0;t <6;t++) {          if(ind[t] >= 0)            break;        }        if(t==6)          break;        index = ind[t];        if(index!=0) {          exp[i] = str.substring(0,index);          i++;        }        exp[i] = str.substring(index,index+1);        str = str.substring(index+1);      }    }    int j = 0;    int k = 0;    for(; exp[j]!=null ;j++){}    if(!exp[j-1].equals(")")) {      exp[j]=str;      str = "";      k = j;    }else {      k = j-1;    }    String[] expp = new String[k+1];    for(int t = 0; t < k+1;t++) {      expp[t] = exp[t];    }    return expp;    //System.out.println("分割的字符串:");  }

2.中綴轉后綴

private static String infToSuf(String[] exp) {    String newStrs = "";    //初始化棧    Stack<String> stack = new Stack<>();     /*           判斷并放入后綴表達式中:       for循環遍歷整個str進行判斷           循環結束若棧不為空全部出棧     */    int l = exp.length;    for(int i = 0; i < l; i++) {      if ((stack.empty()) && (exp[i].equals("+") || exp[i].equals("-") || exp[i].equals("*") || exp[i].equals("/"))) {        stack.push(exp[i]);      } else if (exp[i].equals("(")) {        stack.push(exp[i]);      } else if (exp[i].equals("*") || exp[i].equals("/")) {        while (stack.peek().equals("*") || stack.peek().equals("/")) {          newStrs = newStrs.concat(stack.pop()+" ");          if(stack.isEmpty()) {            break;          }        }        stack.push(exp[i]);      } else if (exp[i].equals("+") || exp[i].equals("-")) {        while (!(stack.isEmpty())&&((stack.peek()).equals("*") || (stack.peek()).equals("/") || (stack.peek()).equals("+") || (stack.peek()).equals("-"))) {          newStrs = newStrs.concat(stack.pop()+" ");          if(stack.isEmpty()) {            break;          }        }        stack.push(exp[i]);      } else if (exp[i].equals(")")) {        int t = stack.search("(");        for (int k = 1; k < t; k++) {          newStrs = newStrs.concat(stack.pop()+" ");        }        String tstr = stack.pop();      } else {        newStrs = newStrs.concat(exp[i]+ " ");      }    }    while (!stack.empty()) {      if (!stack.peek().equals("(") || !stack.peek().equals(")")) {        newStrs = newStrs.concat(stack.pop()+" ");      } else if (stack.peek().equals("(") || stack.peek().equals(")")) {        String tstr = stack.pop();      }    }//   System.out.println("后綴:"+newStrs);    return newStrs;  }

3.后綴的計算

  private static String sufToRes(String sufStr) {    String[] exp = sufStr.split(" ");    Stack<String> stack = new Stack<>();    String Res = "";    for(int i = 0;i < exp.length; i++) {      if(!exp[i].equals("+") && !exp[i].equals("-") && !exp[i].equals("*") && !exp[i].equals("/")){        stack.push(exp[i]);      }else if(exp[i].equals("+")) {        BigDecimal b2 = new BigDecimal(stack.pop());        BigDecimal b1 = new BigDecimal(stack.pop());        BigDecimal b3 = b1.add(b2);        stack.push(b3.toString());      }else if(exp[i].equals("-")) {        BigDecimal b2 = new BigDecimal(stack.pop());        BigDecimal b1 = new BigDecimal(stack.pop());        BigDecimal b3 = b1.subtract(b2);        stack.push(b3.toString());      }else if(exp[i].equals("*")) {        BigDecimal b2 = new BigDecimal(stack.pop());        BigDecimal b1 = new BigDecimal(stack.pop());        BigDecimal b3 = new BigDecimal(0);        if(b1.compareTo(BigDecimal.ZERO)== 0|| b2.compareTo(BigDecimal.ZERO) == 0) {          b3 = BigDecimal.ZERO;        }else {          b3 = b1.multiply(b2);        }        stack.push(b3.toString());      }else if(exp[i].equals("/")){        BigDecimal b2 = new BigDecimal(stack.pop());        BigDecimal b1 = new BigDecimal(stack.pop());        BigDecimal b3 = new BigDecimal(0);        double d1 = b1.doubleValue();        double d2 = b2.doubleValue();        if(d1%d2 == 0){          b3 = (b1.divide(b2));          stack.push(b3.toString());        }else {          b3 = b1.divide(b2,10, RoundingMode.HALF_UP);          stack.push(b3.toString());        }      }    }    Res = stack.pop();    boolean flag = false;    for (int m = 0; m < Res.length() - 1;m++) {      if(Res.charAt(m) == '.'){        flag = true;      }    }    if(flag) {      for(int m = Res.length()-1;m >= 0;m--) {        if(Res.charAt(m) == '0'){        }else {          Res = Res.substring(0,m+1);          break;        }      }      if(Res.charAt(Res.length()-1) == '.') {        Res = Res.substring(0,Res.length()-1);      }    }    return Res;  }

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 免费观看黄色一级视频 | av在线免费观看网 | 爽爽视频免费看 | 久久精品亚洲一区二区三区观看模式 | 91精品国产综合久久婷婷香 | 欧美日韩免费一区 | 一级电影免费看 | 午夜视频在线观看免费视频 | 欧美一级黄色录相 | 国产高清美女一级毛片久久 | 精品一区二区三区日本 | 国产福利视频在线观看 | 国产精品午夜未成人免费观看 | 性看小视频 | 成人在线国产 | 国产亚洲精品久久久久久网站 | 国产成人精品无人区一区 | 毛片免费视频网站 | 免费观看高清视频网站 | 亚洲国产馆 | 久久久精品99 | 国内毛片视频 | 久久久久久久亚洲精品 | 久久久久久久久久久久久国产精品 | 黄色一级毛片免费看 | 国产一国产精品一级毛片 | 九九热精品视频在线 | av电影在线免费观看 | 三级xxxx | 精品国产一区二区三区四区在线 | 久久久久久久.comav | 国产亲子伦在线观看 | 激情小说激情图片激情电影 | 草免费视频 | 黄色毛片一级 | 国产一国产一级毛片视频在线 | 国产精品久久久毛片 | www.精品视频 | 久久国产不卡 | 国产免费小视频在线观看 | 全黄性性激高免费视频 |