코드와이
[SW Expert Academy] 1218. [S/W 문제해결 기본] 4일차 - 괄호 짝짓기 본문
문제링크
package D4;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Stack;
import java.util.StringTokenizer;
public class 괄호_짝짖기 {
static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
static StringTokenizer st;
public static void main(String[] args) throws NumberFormatException, IOException {
StringBuilder sb = new StringBuilder();
for(int tc = 1 ; tc <= 10 ; tc++) {
sb.append("#" + tc + " ");
Stack<String> a = new Stack<String>();
Stack<String> b = new Stack<String>();
Stack<String> c = new Stack<String>();
Stack<String> d = new Stack<String>();
Integer.parseInt(br.readLine());
String[] input = br.readLine().split("");
boolean flag = true;
for( String s : input) {
if(s.equals("(")) a.add(s);
else if(s.equals("[")) b.add(s);
else if(s.equals("{")) c.add(s);
else if(s.equals("<")) d.add(s);
else if(s.equals(")")) {
try{
a.pop();
} catch(Exception e) {
flag = false;
break;
}
}
else if(s.equals("]")) {
try{
b.pop();
} catch(Exception e) {
flag = false;
break;
}
}
else if(s.equals("}")) {
try{
c.pop();
} catch(Exception e) {
flag = false;
break;
}
}
else if(s.equals(">")) {
try{
d.pop();
} catch(Exception e) {
flag = false;
break;
}
}
}
int ans = flag == true && a.size() + b.size() + c.size() + d.size() == 0 ? 1 : 0;
sb.append(ans).append("\n");
}
sb.setLength(sb.length()-1);
System.out.println(sb);
}
}
'SW_Expert' 카테고리의 다른 글
[SW Expert Academy] 1249. [S/W 문제해결 응용] 4일차 - 보급로 (0) | 2021.03.03 |
---|---|
[SW Expert Academy] 1226. [S/W 문제해결 기본] 7일차 - 미로1 (0) | 2021.03.01 |
[SW Expert Academy] 1211.[S/W 문제해결 기본] 2일차 - Ladder2 (0) | 2021.03.01 |
[SW Expert Academy] 7829. 보물왕 태혁 (0) | 2021.02.26 |
[SW Expert Academy] 1219. [S/W 문제해결 기본] 4일차 - 길찾기 (0) | 2021.02.26 |