Problem Solving/Baekjoon
[백준] 2257 화학식량 - Data Structure / Java
graycode
2022. 12. 16. 18:32
• 문제 링크
2257번: 화학식량
첫째 줄에 화학식이 주어진다. 화학식은 H, C, O, (, ), 2, 3, 4, 5, 6, 7, 8, 9만으로 이루어진 문자열이며, 그 길이는 100을 넘지 않는다.
www.acmicpc.net
• 풀이 과정
• 풀이 코드
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Stack;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
String input = br.readLine();
Stack<Integer> stk = new Stack<>();
for (int i = 0; i < input.length(); i++) {
char token = input.charAt(i);
if (token == ')') {
int val = 0;
while (stk.peek() != 0)
val += stk.pop();
stk.pop();
stk.push(val);
} else if (token == 'C')
stk.push(12);
else if (token == 'H')
stk.push(1);
else if (token == 'O')
stk.push(16);
else if (token >= '2' && token <= '9')
stk.push(stk.pop() * (token - '0'));
else
stk.push(0);
}
int sum = 0;
while (!stk.empty())
sum += stk.pop();
bw.write(String.valueOf(sum));
bw.flush();
}
}