C语言请编写一个简单程序,输入正整数n,输出n的阶乘。
时间: 2024-04-17 18:24:59 浏览: 27
```c
#include <stdio.h>
int main() {
int n, factorial = 1;
printf("请输入一个正整数:");
scanf("%d", &n);
if (n < 0) {
printf("输入的数不是正整数!\n");
return 0;
}
for (int i = 1; i <= n; i++) {
factorial *= i;
}
printf("%d的阶乘是:%d\n", n, factorial);
return 0;
}
```
这段程序会先让用户输入一个正整数n,然后使用for循环计算n的阶乘,最后输出结果。如果输入的数不是正整数,则会给出错误提示。
相关问题
c语言编写程序:输入一个正整数,将其阶乘输出,求阶乘用自定义函数实现。
以下是一个简单的C语言程序,用于计算输入正整数的阶乘并输出结果:
```c
#include <stdio.h>
int factorial(int n);
int main()
{
int n, result;
printf("请输入一个正整数: ");
scanf("%d", &n);
result = factorial(n);
printf("%d的阶乘为%d\n", n, result);
return 0;
}
int factorial(int n)
{
int i, result = 1;
for (i = 1; i <= n; i++)
{
result *= i;
}
return result;
}
```
程序中定义了一个自定义函数 `factorial`,用于计算阶乘。在 `main` 函数中,首先提示用户输入一个正整数,然后调用 `factorial` 函数计算阶乘,并将结果输出到屏幕上。
给一个程序,输入正整数n(n<100),输出n的阶乘。提示:注意数值溢出 使用C语言编程
当输入一个正整数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`类型来存储结果,以避免数值溢出。