알고리즘/BOJ

[BOJ] 4949. 균형잡힌 세상

재담 2022. 2. 22. 00:08

문제 원본 : https://www.acmicpc.net/problem/4949

 

4949번: 균형잡힌 세상

하나 또는 여러줄에 걸쳐서 문자열이 주어진다. 각 문자열은 영문 알파벳, 공백, 소괄호("( )") 대괄호("[ ]")등으로 이루어져 있으며, 길이는 100글자보다 작거나 같다. 입력의 종료조건으로 맨 마

www.acmicpc.net

import java.util.Scanner;
import java.util.Stack;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            String s = scanner.nextLine();
            if (s.equals(".")) {
                return;
            }

            Stack<Character> st = new Stack<>();
            boolean isBalanced = true;
            for (int i = 0; i < s.length(); ++i) {
                if (s.charAt(i) == '(' || s.charAt(i) == '[') {
                    st.push(s.charAt(i));
                } else if (s.charAt(i) == ')') {
                    if (st.empty() || st.pop() != '(') {
                        isBalanced = false;
                        break;
                    }
                } else if (s.charAt(i) == ']') {
                    if (st.empty() || st.pop() != '[') {
                        isBalanced = false;
                        break;
                    }
                }
            }

            if (!st.empty()) {
                isBalanced = false;
            }

            System.out.println(isBalanced ? "yes" : "no");
        }
    }
}
  • 스택으로 괄호가 짝을 이루는지 판단하면 되는 쉬운 문제