동캄의 코딩도장

백준 1992 [쿼드트리] 파이썬 본문

코테/BOJ

백준 1992 [쿼드트리] 파이썬

동 캄 2023. 3. 21. 09:46

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

 

1992번: 쿼드트리

첫째 줄에는 영상의 크기를 나타내는 숫자 N 이 주어진다. N 은 언제나 2의 제곱수로 주어지며, 1 ≤ N ≤ 64의 범위를 가진다. 두 번째 줄부터는 길이 N의 문자열이 N개 들어온다. 각 문자열은 0 또

www.acmicpc.net

#백준 1992 쿼드트리
import sys
input=sys.stdin.readline
N=int(input())
field=[]
for _ in range(N):
    field.append(list(map(int,input().rstrip())))
answer=''
def compress(R,C,N):
    global answer
    criteria=field[R][C]
    for i in range(R,R+N):
        for j in range(C,C+N):
            if criteria!=field[i][j]: #만약 모든 값이 같지 않으면
                answer+='(' #괄호 시작
                compress(R,C,N//2)  # 재귀로 반복
                compress(R,C+N//2,N//2)
                compress(R+N//2,C,N//2)
                compress(R+N//2,C+N//2,N//2)
                answer+=')' #괄호 마침
                return
    if criteria==1: #모든 값이 1이면
        answer+='1'
    elif criteria==0: #모든 값이 0이면
        answer+='0'
compress(0,0,N)
print(answer)

분할정복에 관한 문제였다. 어제 관련한 문제를 풀어본 경험이 있어서, 수월하게 해결할 수 있었다. (열심히 해야겠다.)