728x90
https://www.acmicpc.net/problem/9012
문제
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다. 그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
해설
스택을 이용하여 문제를 풀어보았다.
우선 ( 일 때 스택에 넣어주고,
) 일 때 첫번째로 )가 나왔다면 vps가 성립될 수 없다. 이게 아니면 스택이 비어있지 않다면 pop을 통해 (를 지워준다.
만약 스택에 비어있는데 )가 나왔다면 이 또한 vps가 성립될 수 없다.
마지막으로 문자열을 다 확인해보고 스택이 비어있어야 vps가 성립이 된다.
소스 코드
import java.util.*
fun main() {
val n = readLine()!!.toInt()
for (i in 0 until n) {
val input = readLine()!!.split("")
val stack = Stack<String>()
var vps = true
for(j in 1 until input.size - 1) {
if(input[j] == "(") stack.push("(")
else{
if(!stack.isEmpty()) stack.pop()
else {
vps = false
break
}
}
}
if(!stack.isEmpty()) vps = false
if(vps) println("YES")
else println("NO")
}
}
728x90
'PS(Problem Solving) > BOJ' 카테고리의 다른 글
[백준/BOJ] 10845번: 큐 (0) | 2021.12.05 |
---|---|
[백준/BOJ] 4949번: 균형잡힌 세상 (0) | 2021.11.30 |
[백준/BOJ] 10773번: 제로 (0) | 2021.11.28 |
[백준/BOJ] 10828번: 스택 (0) | 2021.11.28 |
[백준/BOJ] 10093번: 숫자 (0) | 2021.11.25 |
댓글