inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어

9.8 팩토리얼 예제

9-8. factorial 예제

해결된 질문

356

이재완

작성한 질문수 28

3

제가 factorial 예제를 제대로 이해했는지 몰라서 질문드립니다.

 


#define CRTSECURE_NO_WARNINGS

#include <stdio.h>

 

long loop_factorial(int n);

long recursive_factorial(int n);

 

int main()

{

    int num = 5;

 

    printf("%d\n", loop_factorial(num));

    printf("%d\n", recursive_factorial(num));

 

    return 0;

}

 

// (1) 반복문 factorial

long loop_factorial(int n)

{

    long ans;

 

    for (ans = 1; n > 1; n--)

        ans *= n;

 

    return ans;

}

 

// (2) 재귀 호출 factorial

long recursive_factorial(int n)

{

    if (n > 0)

        return n * recursive_factorial(n - 1);

    else

        return 1;

}

 


해당 예시 코드에서 (2)번 재귀 호출 factorial 예제 과정에 대해 설명해보겠습니다.

 

(1)처음 n에 argument 5가 대입되면, 0보다 큰 조건을 충족하므로 5 * recursive_fatorial(4)가 반환됩니다.

(2)이후 recursive_factorial(4)가 실행되고, 역시 0보다 큰 조건을 충족하므로 4 *  recursive_factorial(3)이 반환됩니다.

(3)이 과정 끝에 recursive_factorial(0)은 조건을 충족하지 못해 1을 반환합니다.

(4)그렇게 마지막에 반환된 recursive_factorial(0)부터 다시 역순으로 값이 반환됩니다.

(5)1(f(0)) >> 1 * 1(f(0)) >> 2 * 1(f(1)) >> 3 * 2(f(2)) > > 4 * 6(f(3)) >> 5 * 24(f(4)) >> 120(f(5)) 의 순으로 값이 반환되어 결국 main() 함수에서 recursive_factorial(5)의 값은 120이 출력됩니다.

늘 친절한 답변 감사합니다.

c

답변 1

2

Soobak

안녕하세요, 답변 도우미 Soobak 입니다.

네, 과정에 대해 정확하게 설명해주셨습니다.

정말 정확하게 잘 설명해주셨습니다!! 👍👍

Export template 안됨

1

26

2

완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.

1

56

3

main 함수에서 왜 int만 선언이 되는걸까요

1

57

2

8비트 2진수 변환시 왜 1을 더해야하나요?

1

55

2

혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?

1

49

1

프로토타입과 함수간의 인자 불일치

1

73

2

12.12 헤더 관련 질문

1

60

2

Visual Studio Community 2026 사용 문의

1

138

2

Q. 15:30, 부호가 있는 8비트 정수 질문

1

61

2

getchar(), putchar()

1

94

3

강의자리ㅛ

1

80

2

비주얼스튜디오코드로 공부해도 상관없나요?

1

114

2

소스파일안에 여러 파일

1

76

2

F5와 F7의 차이

1

78

2

c = TWO * (a+b); 에서 a와 b는?

1

58

2

; 세미콜론을 붙이는 기준에 문의

1

70

1

Step over 기능 문의

1

53

2

2.6 강의 따옴표 출력 규칙 문의

1

76

2

int main 함수 관련 오류 문의

1

67

2

13.4 words[0]

0

61

2

11.7 함수를 구현해 봤습니다.

1

62

2

11.6 직접 strcmp와 strncmp를 구현해 보았습니다.

1

65

2

11.6 my_strcat과 my_strncat을 구현해봤습니다.

1

53

2

11.6 fit_str함수를 구현해 봤습니다.

1

54

2