c语言计算n!=123*…*(n-1)*n
时间: 2024-07-15 15:00:37 浏览: 76
在C语言中,计算阶乘(n!)通常使用循环或者递归的方法。阶乘是一个数的所有小于及等于它的正整数的乘积,对于给定的n,其阶乘表示为 n! = 1 * 2 * 3 * ... * (n-1) * 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 = 1; // 初始化结果为1
for (int i = 2; i <= n; i++) {
result *= i; // 依次将i乘到result上
}
return result;
}
}
int main() {
int n;
printf("Enter a non-negative integer: ");
scanf("%d", &n);
if (n >= 0) {
unsigned long long fact = factorial(n);
printf("The factorial of %d is: %llu\n", n, fact);
} else {
printf("Invalid input. Please enter a non-negative number.\n");
}
return 0;
}
```
阅读全文