본문 바로가기
Preparing Coding Test/Baekjoon

[Java/백준/스택] 4949 - 균형잡힌 세상

by weero 2020. 9. 6.

문제

https://www.acmicpc.net/problem/4949

 

4949번: 균형잡힌 세상

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

www.acmicpc.net

 

코드

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Stack;

public class Main{
	public static void main(String[] args) throws IOException{
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		ArrayList<String> answer = new ArrayList<String>();
		
		while(true) {
			String ps = br.readLine();
			if(ps.equals(".")){
				break;
			}

			boolean flag = true;
			Stack<String> stack = new Stack<String>();
			
			for(int j=0; j<ps.length(); j++) {
				if(ps.substring(j,j+1).equals("(")) {
					stack.push("(");
				}else if(ps.substring(j,j+1).equals(")")){
					if(stack.isEmpty() || !stack.peek().equals("(")) {
						flag = false;
						break;
					}
					stack.pop();
				}else if(ps.substring(j,j+1).equals("[")) {
					stack.push("[");
				}else if(ps.substring(j,j+1).equals("]")){
					if(stack.isEmpty() || !stack.peek().equals("[")) {
						flag = false;
						break;
					}
					stack.pop();
				}
			}
			if(stack.isEmpty() && flag) {
				answer.add("yes");
			}else {
				answer.add("no");
			}
		}
		
		for(String ans : answer) {
			System.out.println(ans);
		}
	}	
}