[백준/파이썬] 10997번 풀이

업데이트:



문제 정보


풀이

문제

예제를 보고 규칙을 유추한 뒤에 별을 찍어 보세요.

입력 요약
첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다.

출력 요약
첫째 줄부터 차례대로 별을 출력한다.

코드

n = int(input())

space = [[' ']*(4*n-3) for _ in range((4*n-1) if n > 1 else 1)]

def create_universe(idx):
    char = '*' if idx %2 ==  0 else ' '
    # ┌
    for i in range(idx, 4*n-3 - idx):
        space[idx][i] = char
    for i in range(idx, ((4*n-1) if n > 1 else 1)-idx):
        space[i][idx] = char

        
    if n == 1 or idx >= 2*n-2:
        return
    # ┘
    for i in range(idx, 4*n-3-idx):
        space[4*n-2-idx][i] = char
    for i in range(idx+2, 4*n-1-idx):
        space[i][4*n-4-idx] = char
    space[idx+2][4*n-5-idx] = char
        
    create_universe(idx+1)

create_universe(0)

result = ''
for i in range(len(space)):
    if i == 1:
        result += '*\n'
    else :
        result += ''.join(map(str,space[i])) + '\n'

print(result)

설명

핵심은 구현 관점에서 예제를 보고 규칙을 유추한 뒤에 별을 찍어 보세요.를 만족하도록 로직을 구성하는 것입니다.

코드는 입력을 파싱한 뒤 조건 분기와 계산을 순서대로 수행하고, 문제에서 요구한 형식으로 결과를 출력합니다.

경계값과 예외 케이스도 함께 고려해 오답이 나기 쉬운 상황을 방지합니다.



이런 주제는 어떠신가요?

비슷한 난이도와 유형의 문제를 이어서 보면 풀이 감각을 더 빠르게 잡기 좋습니다.

댓글남기기