C语言:用递归函数计算n!
时间: 2024-04-29 07:24:34 浏览: 19
好的,关于计算n!的问题,可以使用递归函数来实现:
```
#include <stdio.h>
long long fact(int n) {
if (n == 0) {
return 1;
} else {
return n * fact(n-1);
}
}
int main() {
int n;
printf("请输入一个正整数:");
scanf("%d", &n);
printf("%d! = %lld\n", n, fact(n));
return 0;
}
```
这是一个简单的示例,如果有更复杂的问题或者需要深入了解,请告诉我。另外,我有一个笑话想和您分享:为什么程序员不能炒股?因为他们喜欢死循环!哈哈哈。
相关问题
C语言编程用递归方法计算n!
好的,下面是计算 n! 的递归实现代码:
```c
#include <stdio.h>
int factorial(int n); // 声明阶乘函数
int main() {
int n = 5;
int result = factorial(n);
printf("%d! = %d\n", n, result);
return 0;
}
int factorial(int n) {
if (n == 0 || n == 1) {
return 1; // 0! 和 1! 都等于1
} else {
return n * factorial(n - 1); // 递归调用计算 n!,n! = n * (n-1)!
}
}
```
这个程序使用了递归的方法来计算 n!。`factorial` 函数首先判断 n 是否等于 0 或 1,如果是,则直接返回 1;否则,递归调用 `factorial` 函数计算 n - 1 的阶乘,并将结果乘以 n,得到 n! 的值。
在主函数中,我们将 n 设为 5,然后调用 `factorial` 函数计算 5! 的值,并将结果输出到屏幕上。运行程序,可以得到以下输出:
```
5! = 120
```
希望能够帮到你!如果你还有其他问题,可以继续问我。
用c语言编程 用递归方法计算n!
好的,以下是用递归方法计算n!的C语言代码:
```c
#include<stdio.h>
int factorial(int n) {
if(n == 0) {
return 1;
} else {
return n * factorial(n-1);
}
}
int main() {
int n;
printf("请输入一个正整数n:");
scanf("%d", &n);
printf("%d! = %d\n", n, factorial(n));
return 0;
}
```
这段代码中,我们定义了一个名为`factorial`的递归函数,用于计算n的阶乘。当输入的n为0时,函数直接返回1,否则函数会递归调用自己,并将n-1作为参数传入。在递归过程中,每个函数都会返回一个值,最终将所有返回值相乘,即得到n的阶乘。
在`main`函数中,我们先输入一个正整数n,然后调用`factorial`函数计算n的阶乘并输出结果。