用递归方法计算整数n的阶乘n!。用递归方法计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input n:" "n<0, data error!\n" **输出格式要求:"%d! = %ld\n"
时间: 2024-05-06 22:17:07 浏览: 156
下面是实现这个功能的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的阶乘,最后输出计算结果。
用函数编写计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input m:" **输出格式要求:"%d! = %ld\n" 程序运行示例如下: Input m:5 5! = 120
下面是使用函数编写计算整数n的阶乘n!的代码:
```python
#include<stdio.h>
long int Factorial(int n); // 声明函数
int main()
{
int n;
printf("Input m:");
scanf("%d", &n);
printf("%d! = %ld\n", n, Factorial(n)); // 调用函数
return 0;
}
long int Factorial(int n)
{
if(n == 0 || n == 1) // 处理特殊情况
return 1;
else
return n * Factorial(n-1); // 递归调用函数
}
```
运行示例如下:
```
Input m:5
5! = 120
```
阅读全文
相关推荐














