언어, 알고리즘 공부/백준

[백준 알고리즘] 4949번 균형잡힌 세상 (Python)

쿠몬e 2020. 3. 13. 19:48

 

<Python>

while True:
    line = input()
    if line == ".":
        break
    stack = []
    check = True

    for ch in line:
        if ch == "(" or ch == "[":
            stack.append(ch)

        elif ch == ")":
            if len(stack) == 0:
                check = False
                break
            if stack[-1] == "(":
                stack.pop()
            else:
                check = False
                break

        elif ch == "]":
            if len(stack) == 0:
                check = False
                break
            if stack[-1] == "[":
                stack.pop()
            else:
                check = False
                break

    if check and len(stack)==0:
        print("yes")
    else:
        print("no")

 

▼ 링크

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

 

4949번: 균형잡힌 세상

문제 세계는 균형이 잘 잡혀있어야 한다. 양과 음, 빛과 어둠 그리고 왼쪽 괄호와 오른쪽 괄호처럼 말이다. 정민이의 임무는 어떤 문자열이 주어졌을 때, 괄호들의 균형이 잘 맞춰져 있는지 판단하는 프로그램을 짜는 것이다. 문자열에 포함되는 괄호는 소괄호("()") 와 대괄호("[]")로 2종류이고, 문자열이 균형을 이루는 조건은 아래와 같다. 모든 왼쪽 소괄호("(")는 오른쪽 소괄호(")")와만 짝을 이뤄야 한다. 모든 왼쪽 대괄호("[")는 오른쪽 대괄

www.acmicpc.net

 

반응형