c语言用数组来求阶乘的代码
时间: 2024-11-30 13:19:54 浏览: 32
当然可以,你可以使用循环结构和数组来计算一个整数的阶乘。这里是一个简单的 C 语言示例,它使用数组存储中间结果,并避免了整数溢出的问题:
```c
#include <stdio.h>
#define MAX_FACT_SIZE 20 // 用于存放最大20!的结果
int factorial(int n, int fact[MAX_FACT_SIZE]) {
if (n == 0 || n == 1) { // 阶乘的基本情况
return 1;
} else {
fact[0] = 1; // 初始化第一个元素为1
for (int i = 1; i <= n; i++) {
fact[i] = fact[i - 1] * i; // 逐次累积乘积
}
return fact[n]; // 返回最后的阶乘值
}
}
int main() {
int num;
printf("请输入一个非负整数:");
scanf("%d", &num);
// 确保输入的数不会超过数组大小
if (num >= MAX_FACT_SIZE) {
printf("抱歉,数字过大无法计算.\n");
return 1;
}
int fact_table[MAX_FACT_SIZE];
int result = factorial(num, fact_table);
printf("该数的阶乘是:%d\n", result);
return 0;
}
阅读全文