문제
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);
}
}
}
'Preparing Coding Test > Baekjoon' 카테고리의 다른 글
[Java/백준/DFS와 BFS] 1260 - DFS와 BFS (0) | 2020.09.10 |
---|---|
[Java/백준/스택] 1874 - 스택 수열 (0) | 2020.09.06 |
[Java/백준/스택] 10773 - 제로 (0) | 2020.09.05 |
[Java/백준/스택] 10828 - 스택 (0) | 2020.09.03 |
[Java/백준/문자열, 스택] 9935 - 문자열 폭발 (0) | 2020.08.28 |