함수형 프로그래밍-재귀

자신을 호출하는 함수를 재귀 함수라고하며이 기술을 재귀라고합니다. 재귀 명령어는 다른 명령어가 방지 할 때까지 계속됩니다.

C ++의 재귀

다음 예제는 객체 지향 프로그래밍 언어 인 C ++에서 재귀가 어떻게 작동하는지 보여줍니다.

#include <stdio.h> 
long int fact(int n);  

int main() { 
   int n; 
   printf("Enter a positive integer: "); 
   scanf("%d", &n); 
   printf("Factorial of %d = %ld", n, fact(n)); 
   return 0; 
} 
long int fact(int n) { 
   if (n >= 1) 
      return n*fact(n-1); 
   else 
      return 1; 
}

다음 출력을 생성합니다.

Enter a positive integer: 5 
Factorial of 5 = 120

파이썬의 재귀

다음 예제는 함수형 프로그래밍 언어 인 Python에서 재귀가 어떻게 작동하는지 보여줍니다.

def fact(n): 
   if n == 1: 
      return n 
   else: 
      return n* fact (n-1)  

# accepts input from user 
num = int(input("Enter a number: "))  
# check whether number is positive or not 

if num < 0: 
   print("Sorry, factorial does not exist for negative numbers") 
else: 
   print("The factorial of " + str(num) +  " is " + str(fact(num)))

다음과 같은 출력이 생성됩니다.

Enter a number: 6
The factorial of 6 is 720