Rego의 블로그
백준 17478 파이썬 재귀함수가 뭔가요? 본문
https://www.acmicpc.net/problem/17478
함수를 반복할 때마다 "_"가 4개씩 늘어난다. 재귀를 이용하여 표현하였다.
recursive(m - 1)에 의하여 if not 문의 변수 m이 0이 될 때가 되어서야 return을 하며,
즉, n - m = 0, 1, 2,..., n. 결국 n번 돈다는 말이다.
이를 이용한 풀이는 아래의 코드와 같다.
def recursive(m):
print("_"*(4*(n - m)) + '"재귀함수가 뭔가요?"')
if not m:
print("_" * (4 * (n - m)) + '"재귀함수는 자기 자신을 호출하는 함수라네"')
print("_" * (4 * (n - m)) + '라고 답변하였지.')
return
print("_" * (4 * (n - m)) + '"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.')
print("_" * (4 * (n - m)) + '마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.')
print("_" * (4 * (n - m)) + '그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어."')
recursive(m - 1)
print("_" * (4 * (n - m)) + "라고 답변하였지.")
n = int(input())
print("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.")
recursive(n)
'BEAKJOON' 카테고리의 다른 글
백준 5543 파이썬 상근날드 (0) | 2021.09.26 |
---|---|
백준 9372 파이썬 상근이의 여행 (0) | 2021.09.25 |
백준 2217 파이썬 로프 (0) | 2021.09.22 |
백준 1874 파이썬 스택 수열 (0) | 2021.09.21 |
백준 9655 파이썬 돌 게임 (0) | 2021.09.20 |