자바 계산기 구현 코드

4718 단어 자바계산기
자바 로 이 루어 진 계산기,원 리 는 코드 주석 을 보고 구체 적 인 내용 은 다음 과 같다.

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

이상 은 모두 이 글 의 전체 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주시 기 바 랍 니 다.

좋은 웹페이지 즐겨찾기