코딩/백준 문제 (브론즈)

[백준/10872/C언어] 팩토리얼 _ 풀이

룻밤 2023. 8. 23. 15:08

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

 

10872번: 팩토리얼

0보다 크거나 같은 정수 N이 주어진다. 이때, N!을 출력하는 프로그램을 작성하시오.

www.acmicpc.net


풀이

#include <stdio.h>
int fac(int n);
int main() {
	int n;
	scanf("%d", &n);
	printf("%d\n", fac(n));
	return 0;
}
int fac(int n) {	// fac(10)
	if (n >= 1)
		return n * fac(n - 1);	// fac(10) = 10*fac(9)
	else 
		return 1;		//n이 0일때는 1
}

팩토리얼은 재귀함수로 구현하면 쉽다.

fac(3) = 3*fac(2)

fac(2) = 2*fac(1)

fac(1) = 1*fac(0)

fac(0) = 1