用C语言写一段代码,计算n!
时间: 2023-05-23 15:02:13 浏览: 59
当n等于0时,n的阶乘为1。当n大于0时,n的阶乘等于n乘以n-1直到1。
以下是一个C语言计算阶乘的函数:
```
#include <stdio.h>
int factorial(int n) {
if (n == 0) {
return 1;
} else {
return n * factorial(n-1);
}
}
int main() {
int n = 5;
printf("factorial of %d is %d\n", n, factorial(n));
return 0;
}
```
在main函数中,我们声明整数n为5,然后调用factorial函数。factorial函数使用递归来计算给定数字的阶乘。如果n等于0,则返回1。否则,返回n与(n-1)的阶乘的乘积。最后,main函数打印阶乘的结果。
如果你想计算其他数字的阶乘,只需将n的值更改为所需的数字即可。
相关问题
用C语言写一段求n!的代码
当然可以!以下是用C语言编写的求!的代码:
```c
#include <stdio.h>
int factorial(int n) {
if (n == 0 || n == 1) {
return 1;
} else {
return n * factorial(n-1);
}
}
int main() {
int n;
printf("请输入一个非负整数: ");
scanf("%d", &n);
if (n < 0) {
printf("输入错误,请输入非负整数!\n");
return 0;
}
int result = factorial(n);
printf("%d的阶乘是:%d\n", n, result);
return 0;
}
```
这段代码首先定义了一个递归函数`factorial`,用于计算阶乘。然后在`main`函数中,读取用户输入的非负整数n,通过调用`factorial`函数计算n的阶乘,并将结果输出给用户。
请注意,这段代码假设用户输入的是非负整数,如果用户输入了负数,则会给出错误提示。
用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的阶乘并输出结果。