문제
https://www.acmicpc.net/problem/17478
코드
def first(cnt):
if cnt > 1:
first(cnt - 1)
print('____' * (cnt - 1) + '"재귀함수가 뭔가요?"')
print('____' * (cnt - 1) + '"잘 들어보게. 옛날옛날 한 산 꼭대기에 이세상 모든 지식을 통달한 선인이 있었어.')
print('____' * (cnt - 1) + '마을 사람들은 모두 그 선인에게 수많은 질문을 했고, 모두 지혜롭게 대답해 주었지.')
print('____' * (cnt - 1) + '그의 답은 대부분 옳았다고 하네. 그런데 어느 날, 그 선인에게 한 선비가 찾아와서 물었어."')
def second(cnt, start):
if cnt > 0:
second(cnt - 1, start + 1)
print('____' * start + '라고 답변하였지.')
N = int(input())
print('어느 한 컴퓨터공학과 학생이 유명한 교수님을 찾아가 물었다.')
first(N)
print('____' * N + '"재귀함수가 뭔가요?"')
print('____' * N + '"재귀함수는 자기 자신을 호출하는 함수라네"')
second(N, 0)
재귀함수를 2개로 나누어 진행했습니다.
중복되는 묶음만 재귀 함수로 실행했고 그렇지 않은 부분은
그냥 print문으로 출력했습니다.
결과
'IT > 알고리즘' 카테고리의 다른 글
백준 - 6603번 (0) | 2020.11.19 |
---|---|
알고리즘 - 재귀 알고리즘(3) (1) | 2020.11.19 |
백준 - 1914번 (0) | 2020.11.18 |
알고리즘 - 재귀 알고리즘(2) (0) | 2020.11.18 |
알고리즘 - 재귀 알고리즘(1) (0) | 2020.11.16 |
댓글