여니의 취준 준비/코딩테스트 (Python)

[n17478] 재귀함수가 뭔가요? in python

여니's 2021. 9. 2. 13:09

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

 

17478번: 재귀함수가 뭔가요?

평소에 질문을 잘 받아주기로 유명한 중앙대학교의 JH 교수님은 학생들로부터 재귀함수가 무엇인지에 대하여 많은 질문을 받아왔다. 매번 질문을 잘 받아주셨던 JH 교수님이지만 그는 중앙대

www.acmicpc.net


문제 제목만 봐도 알 수 있는 유형

> 재귀함수로 푸는 문제

 

재귀횟수 : N

위 예시를 보면, 재귀횟수가 2이다.

 

recursion(2) 호출

recursion(1) 호출

recursion(0) 호출

print('_' * (4 * (n - cnt))+ "라고 답변하였지.") : n-cnt=2

print('_' * (* (n - cnt))+ "라고 답변하였지.") : n-cnt=1

print('_' * (* (n - cnt))+ "라고 답변하였지.") : n-cnt=0

 

n = int(input())
cnt = 1


def recursion(cnt):
    print('_' * (4 * (n - cnt)) + '"재귀함수가 뭔가요?"')

    if cnt == 0:
        print('_' * (4 * (n - cnt))+ '"재귀함수는 자기 자신을 호출하는 함수라네"')
        print('_' * (4 * (n - cnt))+ "라고 답변하였지.")
        return

    print('_' * (4 * (n - cnt)) + '"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.')
    print('_' * (4 * (n - cnt)) + '마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.')
    print('_' * (4 * (n - cnt)) + '그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어."')
    recursion(cnt - 1)
    print('_' * (4 * (n - cnt))+ "라고 답변하였지.")


print("어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.")
recursion(n)