codekata #14

신승호·2021년 5월 14일

codekata

목록 보기
11/15

codekata_0514


재귀 알고리즘

오늘은 재귀알고리즘에 대한 문제입니다.
재귀(recursion)란, 자신을 정의할 때 자기 자신을 호출하는 방법을 뜻합니다. 프로그래밍의 함수정의에서 많이 사용됩니다.

예)

def countdown(n):
  print(n)
  countdown(n-1)

countdown(10);

countdown 함수는 받은 인자를 출력합니다.
그런데 위의 함수를 실행하면 10에서 시작해서 무한으로 마이너스 값까지 내려갑니다.

그래서 재귀함수는 아래의 절차가 꼭 필요합니다.
언제 멈출것인가?

위를 고려해 0이 되면 더이상 재귀를 이어나가지 않도록 종료 조건을 추가하겠습니다.

def countdown(n):
  print(n)
  
  if (n == 0):
    return None
  
  countdown(n-1)

countdown(10);

재귀의 이론은 위와 같이 아주 간단합니다.
재귀를 더 공부하고 싶은 분은 인터넷에 재귀 문제를 찾아 더 풀어보셔도 좋고, 알고리즘 책에서 재귀 부분만 더 읽으셔도 좋습니다.

문제

재귀를 사용하여 팩토리얼(factorial)을 구하는 함수를 구현해주세요.
팩토리얼이란 1에서부터 n까지의 정수를 모두 곱한것을 말합니다.

1! = 1
2! = 1 2
5! = 1
2 3 4 * 5

need to know

  1. 재귀 함수 .. !

문자로 짜봐

  1. 1이나 0이 들어가면 1로 멈춰주자
  2. factorial(n)함수가 계속 돌아가게
  3. 예를들어 3이 들어갔을 때
  • factorial(5)
  • 5 * factorial(4) 가 리턴되고,
  • 그리고 facotrical(4)가 다시가서 계쏙 돌아가는 느낌

정답

def factorial(n):
  if n == 1 or n == 0:
    return 1
  return n * factorial(n-1)

>### 참고
- 재귀 함수 자체를 이해해야된다.. !
profile
신승홉니다

0개의 댓글