使用两种方法求n!
1.迭代
int main()
{
int n = 0;
scanf_s("%d", &n);
int i = 0;
int ret = 1;
//迭代(循环是一种迭代的方式)
for (i = 1; i <= n; i++)
{
ret = ret * i;
}
printf("%d\n", ret);
return 0;
}
2.递归
int Fac(int n)
{
if (n <= 1)
return 1;
else
return n * Fac(n - 1);
}
int main()
{
int n = 0;
scanf_s("%d", &n);
int ret = Fac(n);
printf("%d\n", ret);
return 0;
}
递归图解