用递归方法计算整数n的阶乘n!。用递归方法计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input n:" "n<0, data error!\n" **输出格式要求:"%d! = %ld\n"
时间: 2024-05-06 21:17:07 浏览: 41
下面是实现这个功能的C语言代码:
```c
#include <stdio.h>
long factorial(int n);
int main()
{
int n;
printf("Input n: ");
scanf("%d", &n);
if (n < 0) {
printf("n<0, data error!\n");
return 0;
}
printf("%d! = %ld\n", n, factorial(n));
return 0;
}
long factorial(int n)
{
if (n == 0) {
return 1;
} else {
return n * factorial(n - 1);
}
}
```
这段代码中,我们定义了一个递归函数`factorial`,用于计算整数n的阶乘。当n为0时,直接返回1;否则,递归调用`factorial(n-1)`,并将结果乘以n,最终返回结果。
在`main`函数中,我们先读入整数n,如果n小于0,则输出错误信息;否则,调用`factorial`函数计算n的阶乘,并输出结果。
相关问题
c语言用递归方法计算整数n的阶乘n!
以下是用递归方法计算整数n的阶乘n!的C语言代码:
```c
#include <stdio.h>
int factorial(int n) {
if (n == 0 || n == 1) { // 当n等于0或1时,直接返回1
return 1;
} else { // 否则,递归调用函数自身,计算n的阶乘
return n * factorial(n - 1);
}
}
int main() {
int n;
printf("Please enter an integer: ");
scanf("%d", &n);
printf("%d! = %d\n", n, factorial(n));
return 0;
}
```
在上面的代码中,`factorial()`函数用于计算整数n的阶乘,当n等于0或1时,直接返回1;否则,递归调用函数自身,计算n的阶乘。`main()`函数用于获取用户输入的整数n,并调用`factorial()`函数计算n的阶乘,最后输出计算结果。
用C语言用递归方法计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input n:" "n<0, data error!\n" **输出格式要求:"%d! = %ld\n"
以下是使用递归方法计算整数n的阶乘n!的C语言代码:
```c
#include <stdio.h>
long factorial(int n)
{
if (n < 0) {
printf("n<0, data error!\n");
return -1;
} else if (n == 0 || n == 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
int main()
{
int n;
printf("Input n: ");
scanf("%d", &n);
long result = factorial(n);
if (result != -1) {
printf("%d! = %ld\n", n, result);
}
return 0;
}
```
首先定义一个函数`factorial`,该函数使用递归方法计算整数n的阶乘。如果输入的n小于0,则输出错误信息并返回-1,否则如果n等于0或者1,则直接返回1,否则递归调用`factorial`函数计算n-1的阶乘,并将结果乘以n。最后在`main`函数中读取用户输入的n,调用`factorial`函数计算n的阶乘,并输出结果。如果`factorial`函数返回值为-1,则说明输入的n有误,不输出结果。