💡문제접근
- 재귀 알고리즘을 공부할 수 있는 가장 기초적인 문제다.
💡코드(메모리 : 31256KB, 시간 : 40ms)
import sys
input = sys.stdin.readline
sys.setrecursionlimit(10**6)
N = int(input())
print("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.")
def recursive(M):
if M == 0:
print("_" * (4 * (N - M)) + '"재귀함수가 뭔가요?"')
print("_" * (4 * (N - M)) + '"재귀함수는 자기 자신을 호출하는 함수라네"')
print("_" * (4 * (N - M)) + "라고 답변하였지.")
return
else:
print("_" * (4 * (N - M)) + '"재귀함수가 뭔가요?"')
print("_" * (4 * (N - M)) + '"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.')
print("_" * (4 * (N - M)) + "마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.")
print("_" * (4 * (N - M)) + '그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어."')
recursive(M-1)
print("_" * (4 * (N - M)) + "라고 답변하였지.")
recursive(N)
💡소요시간 : 11m