코딩/백준 문제 (브론즈)
[백준/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