7-2 计算阶乘和 c语言
时间: 2024-09-14 08:07:59 浏览: 49
c语言-阶乘算法(迭代和递归).docx
在 C 语言中,计算阶乘通常涉及到递归或者循环的方式。下面是一个简单的非递归方法来计算一个整数 n 的阶乘:
```c
#include <stdio.h>
unsigned long long factorial(int n) {
if (n == 0 || n == 1) { // 阶乘的基本情况,0和1的阶乘都是1
return 1;
} else {
unsigned long long result = n; // 初始化结果为当前数值
for (int i = 2; i <= n; ++i) {
result *= i; // 逐次将每个数字乘到结果上
}
return result;
}
}
int main() {
int num;
printf("请输入一个整数:");
scanf("%d", &num);
printf("%d! 的阶乘是 %llu\n", num, factorial(num));
return 0;
}
```
在这个程序中,`factorial` 函数接收一个整数作为输入,如果输入是 0 或 1,则直接返回 1;否则,通过一个 for 循环将从 2 到 n 的所有整数相乘,得到阶乘的结果。
阅读全文