C语言 编写程序,输入一个正整数n值,求 n!的值
时间: 2024-09-26 10:15:37 浏览: 11
在C语言中,计算一个正整数n的阶乘(n!)是一个常见的数学问题,阶乘表示的是从1到n的所有整数的积。下面是一个简单的C程序,用于输入一个正整数n并计算它的阶乘:
```c
#include <stdio.h>
// 定义一个函数来计算阶乘
unsigned long long factorial(int n) {
if (n == 0 || n == 1) { // 阶乘的基本情况:0! = 1
return 1;
} else {
return n * factorial(n - 1); // 递归调用,计算n-1的阶乘再乘以n
}
}
int main() {
int n;
printf("请输入一个正整数: ");
scanf("%d", &n);
if (n < 0) {
printf("抱歉,负数没有阶乘。\n");
} else {
unsigned long long result = factorial(n);
printf("n! 的值是: %llu\n", result);
}
return 0;
}
```
在这个程序中,我们首先检查输入的n是否小于0,因为负数的阶乘在数学上是没有定义的。然后,如果n是非负整数,我们就通过递归的方式计算阶乘。
相关问题
编写程序,输入一个正整数n值,求 n!的值。
在C语言中,为了计算一个正整数`n`的阶乘(`n!`),我们可以使用递归的方式。如果`n`是1,则其阶乘为1;否则`n`的阶乘就是`n * (n - 1)!`。下面是一个简单的递归函数示例:
```c
#include <stdio.h>
// 定义递归函数计算阶乘
unsigned long long factorial(int n) {
if (n == 1) { // 基线条件:1的阶乘为1
return 1;
} else {
return n * factorial(n - 1); // 递归调用,n * (n - 1)!
}
}
int main() {
int n;
printf("请输入一个正整数: ");
scanf("%d", &n);
if (n < 0) {
printf("抱歉,负数没有阶乘。\n");
} else {
unsigned long long result = factorial(n);
printf("n!的结果是: %llu\n", result);
}
return 0;
}
```
注意,对于较大的`n`值,`n!`可能会超出标准`int`类型的范围,所以这里使用了`unsigned long long`类型来存储结果。
输入一个正整数n判断是否为素数,用c语言编写程序
以下是判断一个正整数是否为素数的C语言程序:
```c
#include <stdio.h>
int main() {
int n, i, flag = 0;
printf("输入一个正整数:");
scanf("%d", &n);
for (i = 2; i <= n / 2; ++i) {
// 如果n能被i整除,则n不是素数
if (n % i == 0) {
flag = 1;
break;
}
}
if (n == 1) {
printf("1既不是素数也不是合数。");
}
else {
if (flag == 0)
printf("%d是素数。", n);
else
printf("%d不是素数。", n);
}
return 0;
}
```