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

업데이트:



문제 정보


풀이

문제

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

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

출력 요약
규칙대로 별을 출력한다.

코드

n = int(input())

print('*'*n + ' ' * (2*n-3) + '*'*n)
for i in range(1, n-1):
    print(' '*i + '*' + ' '*(n-2) + '*' + ' '*(2*(n-i)-3) + '*' + ' '*(n-2) + '*')
print(' '*(n-1) + '*' + ' '*(n-2) + '*' + ' '*(n-2) + '*')
for i in range(n-2, 0, - 1):
    print(' '*i + '*' + ' '*(n-2) + '*' + ' '*(2*(n-i)-3) + '*' + ' '*(n-2) + '*')
print('*'*n + ' ' * (2*n-3) + '*'*n)

설명

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

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

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



다음 읽을거리

관련 허브 페이지에서 같은 주제의 글을 이어서 확인할 수 있습니다.

댓글남기기