c语言计算阶乘的函数
时间: 2023-12-28 09:23:21 浏览: 280
以下是两种C语言计算阶乘的函数的例子:
1.使用for循环计算阶乘
```c
#include <stdio.h>
void factorial() {
int number;
int factorial = 1;
scanf("%d", &number);
for(int i=1; i<=number; i++) {
factorial = i*factorial;//确保即便当number=0的时候,结果也为1
}
printf("%d ", factorial);
}
int main() {
factorial();//直接调用计算阶乘的函数
return 0;
}
```
2.使用递归函数计算阶乘
```c
#include <stdio.h>
long fact(int n) {
static long pro = 1;//pro即product---乘积
pro = pro * n;
return(pro);
}
int main() {
int n, m = 1, pro;
printf("Input n:");
scanf("%d", &n);
for (; m <= n; m++) {
pro = fact(m);
}
printf("%d!=%ld\n", n, pro);
return 0;
}
```
相关问题
用c语言定义阶乘函数
在C语言中,你可以通过递归或者循环的方式定义阶乘函数。这里给出两种常见的实现方法:
**1. 递归实现:**
```c
#include <stdio.h>
// 递归定义阶乘函数
unsigned long long factorial(int n) {
if (n == 0 || n == 1) { // 阶乘的基本情况
return 1;
} else {
return n * factorial(n - 1); // 递归调用自身
}
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
printf("结果是:%llu\n", factorial(num));
return 0;
}
```
**2. 循环实现:**
```c
#include <stdio.h>
unsigned long long factorial(int n) {
unsigned long long result = 1; // 初始化结果为1
for (int i = 2; i <= n; ++i) {
result *= i; // 依次累乘
}
return result;
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
printf("结果是:%llu\n", factorial(num));
return 0;
}
```
这两种方法都可以计算给定整数的阶乘,递归版简洁直观,但当n较大时可能会导致栈溢出;而循环版本则更高效,不会遇到这个问题。
如何用c语言计算阶乘
在C语言中计算阶乘通常会用到递归或者循环结构。这里提供两个简单的例子:
**使用递归方法计算阶乘:**
```c
#include <stdio.h>
// 定义递归函数
unsigned long long factorial(int n) {
if (n == 0 || n == 1) // 阶乘的基本情况,0和1的阶乘都是1
return 1;
else
return n * factorial(n - 1); // 递归调用自身,n * (n-1)! = n!
}
int main() {
int number;
printf("请输入一个正整数:");
scanf("%d", &number);
printf("%d 的阶乘是 %llu\n", number, factorial(number));
return 0;
}
```
**使用循环方法计算阶乘:**
```c
#include <stdio.h>
#include <limits.h> // 引入ULLONG_MAX用于处理大数
unsigned long long factorial(int n) {
unsigned long long result = 1;
for (int i = 1; i <= n; ++i) {
result *= i;
// 检查结果是否超过最大值,防止溢出
if (result > ULLONG_MAX && i != n)
break;
}
return result;
}
int main() {
int number;
printf("请输入一个正整数:");
scanf("%d", &number);
printf("%d 的阶乘是 %llu\n", number, factorial(number));
return 0;
}
```
这两个示例都会计算用户输入的正整数的阶乘。注意递归方法可能会因为调用栈过深导致堆栈溢出,所以对于较大的数值,循环方法更为合适。
阅读全文