// // Created by Paik Seung Cheol on 2020. 3. 19.. // publicclassCalculator{ publicstaticvoidmain(String[] args){ double result = postFixCalc("132**"); System.out.println(result); }
publicstaticdoublepostFixCalc(String data){ Stack<Double> stack = new ArrayStack<>();
for (int i = 0; i < data.length(); i++) { switch (data.charAt(i)) { case'*': case'-': case'+': case'/': double op1 = new BigDecimal(stack.pop()).doubleValue(); double op2 = new BigDecimal(stack.pop()).doubleValue(); double result = calculate(data.charAt(i), op1, op2); stack.push(result); break; default: int num = Character.digit(data.charAt(i),10); stack.push(new BigDecimal(num).doubleValue()); } } double result = 0; while(!stack.isEmpty()) { result = stack.pop(); } return result; }
privatestaticdoublecalculate(char postfixExp, double op1, double op2){ double result =0;
switch (postfixExp) { case'*': result = new BigDecimal(op1).multiply(new BigDecimal(op2)).doubleValue(); break; case'-': result = new BigDecimal(op1).subtract(new BigDecimal(op2)).doubleValue(); break; case'+': result = new BigDecimal(op1).add(new BigDecimal(op2)).doubleValue(); break; case'/': result = new BigDecimal(op1).divide(new BigDecimal(op2)).doubleValue(); break; default : break; } return result; } }
Posted onEdited onInComputer
,
CodingTestDisqus: Symbols count in article: 1.9kReading time ≈2 mins.
[BaekJoon-9012] 괄호
문제
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다. 그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
입력
입력 데이터는 표준 입력을 사용한다. 입력은 T개의 테스트 데이터로 주어진다. 입력의 첫 번째 줄에는 입력 데이터의 수를 나타내는 정수 T가 주어진다. 각 테스트 데이터의 첫째 줄에는 괄호 문자열이 한 줄에 주어진다. 하나의 괄호 문자열의 길이는 2 이상 50 이하이다.
출력
출력은 표준 출력을 사용한다. 만일 입력 괄호 문자열이 올바른 괄호 문자열(VPS)이면 “YES”, 아니면 “NO”를 한 줄에 하나씩 차례대로 출력해야 한다.
publicstaticvoidparenthesis()throws Exception { BufferedReader in = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out));
int t = parseInt(in.readLine()); while (0 < t--) { Stack<Character> stack = new Stack<>(); String ps = in.readLine(); String result = "YES"; for (int i = 0; i <ps.length(); i++) { char ch = ps.charAt(i); if (ch == '(') { stack.push(ch); continue; } if (stack.empty()) { result = "NO"; break; } stack.pop(); } if (result.equals("YES") && !stack.empty()) { result = "NO"; } out.write(result); out.write('\n'); out.flush();; } out.close(); in.close(); }
publicstaticvoidflipWord()throws Exception { BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out)); BufferedReader in = new BufferedReader(new InputStreamReader(System.in)); int t = parseInt(in.readLine());
while (0 < t--) { Stack<Character> stack = new Stack<>(); String word = in.readLine() + "\n"; for (int i = 0; i < word.length(); i++) { char ch = word.charAt(i); if (ch != ' ' && ch != '\n') { stack.push(ch); continue; } while(!stack.isEmpty()) { out.write(stack.pop()); } out.write(ch); } out.flush(); } out.close();; in.close();; }
publicstaticvoidmain(String[] args)throws Exception { stack(); } publicstaticvoidstack()throws Exception { BufferedReader in = new BufferedReader(new InputStreamReader(System.in)); BufferedWriter out = new BufferedWriter(new OutputStreamWriter(System.out)); int n = parseInt(in.readLine()); String stack[] = new String[n]; int size = -1;