给一个程序,输入正整数n(n<100),输出n的阶乘。提示:注意数值溢出 使用C语言编程
时间: 2024-04-11 15:25:58 浏览: 21
当输入一个正整数n(n<100),计算n的阶乘可以使用循环来实现。以下是一个用C语言编写的程序示例:
```c
#include <stdio.h>
long long factorial(int n) {
long long result = 1;
for (int i = 1; i <= n; i++) {
result *= i;
}
return result;
}
int main() {
int n;
printf("请输入一个正整数n(n<100):");
scanf("%d", &n);
if (n < 0 || n >= 100) {
printf("输入错误!请重新运行程序并输入一个合法的正整数n(n<100)。\n");
return 0;
}
long long result = factorial(n);
printf("%d 的阶乘是 %lld\n", n, result);
return 0;
}
```
这个程序通过循环计算n的阶乘,并将结果输出。请注意,由于阶乘的结果可能非常大,所以我使用了`long long`类型来存储结果,以避免数值溢出。
相关问题
C语言输入一个正整数n,n<=20;求n的阶层
以下是C语言程序实现:
```c
#include <stdio.h>
int main()
{
int n, i;
unsigned long long factorial = 1; // 使用unsigned long long类型存储阶乘,避免溢出
printf("请输入一个正整数n(n<=20):");
scanf("%d", &n);
// 求阶乘
for (i = 1; i <= n; i++)
{
factorial *= i;
}
printf("%d的阶乘为%llu\n", n, factorial);
return 0;
}
```
该程序使用for循环计算n的阶乘,使用unsigned long long类型存储阶乘,避免因阶乘过大导致计算结果溢出。
用C语言从键盘上输入一个小于20的任意正整数,计算其阶乘。
好的,以下是C语言代码实现:
```c
#include <stdio.h>
int main() {
int n;
long long factorial = 1;
// 从键盘上输入一个小于20的正整数
do {
printf("请输入一个小于20的正整数:");
scanf("%d", &n);
} while (n < 1 || n >= 20);
// 计算阶乘
for (int i = 1; i <= n; i++) {
factorial *= i;
}
// 输出计算结果
printf("%d的阶乘为%lld\n", n, factorial);
return 0;
}
```
以上代码使用了 `do-while` 循环来保证输入的正整数小于20,然后使用 `for` 循环计算输入正整数的阶乘,最后输出计算结果。注意,由于输入的正整数较大,为了防止计算过程中发生数据溢出,使用了 `long long` 类型来存储计算结果。