C语言如何求n的阶乘?
时间: 2024-01-13 15:45:35 浏览: 87
可以使用循环结构来求解n的阶乘,具体代码如下:
```c
#include <stdio.h>
int main() {
int n, i, fact = 1;
printf("请输入一个正整数:");
scanf("%d", &n);
for (i = 1; i <= n; i++) {
fact *= i;
}
printf("%d的阶乘是%d\n", n, fact);
return 0;
}
```
在这个程序中,我们先要从用户那里获取一个正整数n,然后通过for循环来计算n的阶乘。在循环中,我们从1开始递增,每次将i乘到fact中,最终得到的fact就是n的阶乘。
相关问题
怎么用c语言表示n的阶乘?
在C语言中,计算一个数n的阶乘(n!)可以通过递归或循环的方式实现。这里我给你介绍两种常见的方法:
1. **递归方法**:
递归是一种直接的方法,当n等于1时,返回1;否则返回n乘以(n-1)的阶乘。
```c
#include <stdio.h>
unsigned long long factorial(int n) {
if (n == 0 || n == 1)
return 1;
else
return n * factorial(n - 1);
}
int main() {
int num;
printf("Enter a non-negative integer: ");
scanf("%d", &num);
if(num >= 0){
unsigned long long result = factorial(num);
printf("Factorial of %d is %llu\n", num, result);
} else {
printf("Invalid input! Please enter a non-negative number.\n");
}
return 0;
}
```
2. **循环方法**:
使用循环来避免无限递归,从1开始一直乘到n。
```c
#include <stdio.h>
unsigned long long factorial(int n) {
unsigned long long fact = 1;
for (int i = 1; i <= n; ++i) {
fact *= i;
}
return fact;
}
int main() {
int num;
printf("Enter a non-negative integer: ");
scanf("%d", &num);
if(num >= 0){
unsigned long long result = factorial(num);
printf("Factorial of %d is %llu\n", num, result);
} else {
printf("Invalid input! Please enter a non-negative number.\n");
}
return 0;
}
```
**相关问题**:
1. 递归方法和循环方法有什么区别?
2. 为什么要用`unsigned long long`类型存储阶乘结果?
3. 阶乘运算可能会导致溢出吗?如何处理大整数阶乘?
4. 如果要计算非常大的数的阶乘,还可以考虑什么算法或库?
c语言求奇数阶乘的和
以下是求奇数阶乘的和的 C 语言代码:
```c
#include <stdio.h>
int main() {
int n, i, j, fact, sum = 0;
printf("Enter a positive integer: ");
scanf("%d", &n);
for (i = 1; i <= n; i++) {
fact = 1;
for (j = 1; j <= 2 * i - 1; j++) {
fact *= j;
}
if (i % 2 != 0) {
sum += fact;
}
}
printf("The sum of odd factorials up to %d is %d", n, sum);
return 0;
}
```
程序首先要求用户输入一个正整数 n,然后使用 for 循环计算每个奇数阶乘,如果当前迭代的 i 是奇数,就将计算的阶乘加到 sum 变量中。最后,程序输出结果:奇数阶乘的和。
阅读全文