c语言求n的阶乘代码
时间: 2023-08-12 07:22:36 浏览: 392
以下是求n的阶乘的C语言代码:
```c
#include <stdio.h>
int main() {
int n, factorial = 1;
printf("请输入一个正整数: ");
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
factorial *= i;
}
printf("%d的阶乘是%d", n, factorial);
return 0;
}
```
首先,我们定义了两个变量 `n` 和 `factorial`,其中 `n` 用于存储用户输入的正整数,`factorial` 初始值为 1,用于存储阶乘的结果。
然后,我们通过 `scanf` 函数从用户那里获取整数 `n`。
接下来,我们使用 `for` 循环计算 `n` 的阶乘。循环变量 `i` 初始值为 1,每次循环时 `factorial` 都乘以当前的 `i` 值。循环结束后,`factorial` 存储的就是 `n` 的阶乘。
最后,我们使用 `printf` 函数将结果输出到屏幕上。
相关问题
C语言递归求阶乘代码
在C语言中,你可以使用递归来编写计算阶乘的程序。递归是一种函数自身调用的方式,对于阶乘问题,它的基本思路是n的阶乘(n!)等于n乘以(n-1)的阶乘。下面是一个简单的示例:
```c
#include <stdio.h>
// 定义递归函数,计算阶乘
long long factorial(int n) {
// 递归的基本情况:0的阶乘为1
if (n == 0 || n == 1)
return 1;
else
// 递归调用,将大问题分解成小问题
return n * factorial(n - 1);
}
int main() {
int num;
printf("请输入一个非负整数:");
scanf("%d", &num);
// 检查输入是否合法,并打印结果
if (num < 0) {
printf("抱歉,输入的数字应该是非负整数。\n");
} else {
long long result = factorial(num);
printf("%d的阶乘是 %lld\n", num, result);
}
return 0;
}
```
当你运行这个程序并输入一个数时,它会返回该数的阶乘。注意递归可能会导致栈溢出,特别是对于较大的数值,因此实际应用中可能需要考虑使用循环或其他优化。
c语言100的阶乘代码
C语言实现100的阶乘可以使用循环的方式来计算。下面是一个简单的代码示例:
```c
#include <stdio.h>
unsigned long long calculateFactorial(int n) {
unsigned long long factorial = 1;
for (int i = 1; i <= n; i++) {
factorial *= i;
}
return factorial;
}
int main() {
int num = 100;
unsigned long long result = calculateFactorial(num);
printf("%d的阶乘为:%llu\n", num, result);
return 0;
}
```
首先,在代码中定义了一个用于计算阶乘的函数`calculateFactorial`。该函数接受一个整数参数n,并初始化一个初始值为1的阶乘变量`factorial`。然后,通过for循环从1到n,依次乘以每个数,得到最终的阶乘结果。最后,返回计算的阶乘值。
在`main`函数中,定义一个整数变量`num`并初始化为100,然后调用`calculateFactorial`函数计算阶乘,并将结果打印输出。
最后,编译并运行程序,输出结果即为100的阶乘。
阅读全文