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

}