编写程序,输入一个正整数n值,求 n!的值。
时间: 2024-09-26 17:17:24 浏览: 42
在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`类型来存储结果。
相关问题
C语言 编写程序,输入一个正整数n值,求 n!的值
在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层金字塔
好的,那么我们可以使用循环语句来编写这个程序。
首先,我们需要使用 `input` 函数来获取用户输入的数字。然后,我们可以使用一个 `for` 循环来遍历每一层金字塔。在每一次循环中,我们可以使用一个内层循环来输出每一层的星号。
具体来说,我们可以使用两个变量来控制循环,一个变量 `i` 表示当前层数,另一个变量 `j` 表示当前层中的星号数。在内层循环中,我们可以使用一个 `if` 语句来判断是否输出星号。如果当前的 `j` 小于等于 `i`,那么就输出一个星号;否则,就输出一个空格。
综上,我们可以使用以下代码来实现这个程序:
```
n = int(input("请输入一个正整数:"))
for i in range(1, n+1):
for j in range(1, n+1):
if j <= i:
print("*", end="")
else:
print(" ", end="")
print()
```
希望这对你有帮助。
阅读全文