PS(Problem Solving)/BOJ

[백준/BOJ] 9012번: 괄호

JunsuKim 2021. 11. 29.
728x90

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

 

9012번: 괄호

괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고

www.acmicpc.net

문제

괄호 문자열(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

댓글