C语言用函数编写计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input m:" **输出格式要求:"%d! = %ld\n" 程序运行示例如下: Input m:5 5! = 120
时间: 2023-12-25 14:05:45 浏览: 53
好的,以下是用 C 语言函数编写计算整数 n 的阶乘 n! 的代码:
```c
#include <stdio.h>
long factorial(int n);
int main() {
int n;
printf("Input m:");
scanf("%d", &n);
printf("%d! = %ld\n", n, factorial(n));
return 0;
}
long factorial(int n) {
if (n == 0 || n == 1) {
return 1;
} else {
return n * factorial(n - 1);
}
}
```
使用递归方式实现了计算阶乘的函数 `factorial()`,并在 `main()` 函数中调用并输出结果。
相关问题
用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有误,不输出结果。
用递归方法计算整数n的阶乘n!。用递归方法计算整数n的阶乘n!。 **输入格式要求:"%d" 提示信息:"Input n:" "n<0, data error!\n" **输出格式要求:"%d! = %ld\n"
下面是实现这个功能的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的阶乘,并输出结果。