boj2504 - 괄호의 값(Kotlin)

이상욱·2022년 12월 1일
0

알고리즘

목록 보기
15/18

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

문제 설명

4개의 기호 ‘(’, ‘)’, ‘[’, ‘]’를 이용해서 만들어지는 괄호열 중에서 올바른 괄호열이란 다음과 같이 정의된다.

한 쌍의 괄호로만 이루어진 ‘()’와 ‘[]’는 올바른 괄호열이다.
만일 X가 올바른 괄호열이면 ‘(X)’이나 ‘[X]’도 모두 올바른 괄호열이 된다.
X와 Y 모두 올바른 괄호열이라면 이들을 결합한 XY도 올바른 괄호열이 된다.
예를 들어 ‘(()[[]])’나 ‘(())[][]’ 는 올바른 괄호열이지만 ‘([)]’ 나 ‘(()()[]’ 은 모두 올바른 괄호열이 아니다. 우리는 어떤 올바른 괄호열 X에 대하여 그 괄호열의 값(괄호값)을 아래와 같이 정의하고 값(X)로 표시한다.

‘()’ 인 괄호열의 값은 2이다.
‘[]’ 인 괄호열의 값은 3이다.
‘(X)’ 의 괄호값은 2×값(X) 으로 계산된다.
‘[X]’ 의 괄호값은 3×값(X) 으로 계산된다.
올바른 괄호열 X와 Y가 결합된 XY의 괄호값은 값(XY)= 값(X)+값(Y) 로 계산된다.
예를 들어 ‘(()[[]])([])’ 의 괄호값을 구해보자. ‘()[[]]’ 의 괄호값이 2 + 3×3=11 이므로 ‘(()[[]])’의 괄호값은 2×11=22 이다. 그리고 ‘([])’의 값은 2×3=6 이므로 전체 괄호열의 값은 22 + 6 = 28 이다.

여러분이 풀어야 할 문제는 주어진 괄호열을 읽고 그 괄호값을 앞에서 정의한대로 계산하여 출력하는 것이다.

입력
첫째 줄에 괄호열을 나타내는 문자열(스트링)이 주어진다. 단 그 길이는 1 이상, 30 이하이다.

출력
첫째 줄에 그 괄호열의 값을 나타내는 정수를 출력한다. 만일 입력이 올바르지 못한 괄호열이면 반드시 0을 출력해야 한다.

문제 풀이

  1. ' ( ' 를 만나면 tmp에 2를 곱해주고 스택에 넣어준다.
  2. ' [ ' 를 만나면 tmp에 3을 곱해주고 스택에 넣어준다.
  3. ' ) ' 를 만났을 때 만약 스택이 비어있거나 stk.peek()값이 '('이 아니면 answer = 0 하고 빠져나간다. 만약 바로 앞의 문자열이 '('라면 answer에 tmp 를 더해준다. 그렇지 않으면 tmp를 2로 나눠주고 stk.pop()를 한다.
  4. ' ] '를 만났을 때 만약 스택이 비어있거나 stk.peek()값이 '['이 아니면 answer = 0 하고 빠져나간다. 만약 바로 앞의 문자열이 '['라면 answer에 tmp 를 더해준다. 그렇지 않으면 tmp를 3로 나눠주고 stk.pop()를 한다.
  5. 마지막에 스택이 아직 비어있지 않으면 0을 출력하고 그렇지 않으면 answer를 출력한다

코드(Kotlin)

import java.util.*

class boj2504 {

    fun sol() {

        var answer = 0
        var tmp = 1

        val input = readLine()!!
        val stk = Stack<Char>()

        for (i in input.indices) {

            when (input[i]) {
                '(' -> {
                    tmp *= 2
                    stk.push(input[i])
                }

                ')' -> {
                    if(stk.isEmpty()||stk.peek() != '('){
                        answer = 0
                        break
                    }else if(input[i-1] =='('){
                        answer += tmp
                    }

                    tmp/=2
                    stk.pop()
                }

                '[' -> {
                    tmp *= 3
                    stk.push(input[i])
                }

                ']' -> {
                    if(stk.isEmpty()||stk.peek() != '['){
                        answer = 0
                        break
                    }else if(input[i-1] =='['){
                        answer += tmp
                    }

                    tmp/=3
                    stk.pop()
                }

            }
        }
            
        if(stk.isNotEmpty()){
            println(0)
        }else{
             println(answer)
        }
        

    }
}

fun main() {
    boj2504().sol()
}
profile
항상 배우고 성장하는 안드로이드 개발자

0개의 댓글