C语言编程用递归方法计算n!
时间: 2023-12-11 10:05:37 浏览: 144
好的,下面是计算 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语言 用递归函数编程计算1!+3!+5!+…+n!(n为奇数)。
```c
#include <stdio.h>
int factorial(int n) {
if (n == 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int n, sum = 0;
scanf("%d", &n);
for (int i = 1; i <= n; i += 2) {
sum += factorial(i);
}
printf("%d", sum);
return 0;
}
```
--相关问题--:
1. 请问递归函数的优缺点是什么?
2. 如何用循环实现
编程用递归函数求n!,然后调用该函数计算5!+7!+9!的值。使用C语言
可以使用递归函数来求解n!,代码如下:
```
#include <stdio.h>
int factorial(int n) {
if (n == 0) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main() {
int result = 0;
result += factorial(5);
result += factorial(7);
result += factorial(9);
printf("%d\n", result);
return 0;
}
```
首先定义了一个递归函数factorial,用来计算n的阶乘。当n为0时,返回1;否则返回n乘以n-1的阶乘。在main函数中,调用factorial函数分别计算5!、7!和9!的值,然后将它们相加,最后输出结果。
阅读全文