C语言编程用函数的递归调用编程求n
时间: 2024-05-02 18:22:35 浏览: 15
的阶乘应该怎么写?
您可以使用以下代码来计算n的阶乘:
```c
#include <stdio.h>
long int factorial(int n);
int main()
{
int n;
long int fact = 1;
printf("请输入一个正整数:");
scanf("%d", &n);
if (n < 0)
printf("错误!负数没有阶乘。");
else
{
fact = factorial(n);
printf("%d 的阶乘为 %ld\n", n, fact);
}
return 0;
}
long int factorial(int n)
{
if (n == 0)
return 1;
else
return (n * factorial(n - 1));
}
```
这是一个递归函数,它将自己调用来计算n的阶乘。如果n为0,则返回1,否则返回n乘以(n-1)的阶乘。
相关问题
用函数递归方法求n!,c语言编程
可以使用以下的C语言代码来实现n的阶乘的递归实现:
```c
#include <stdio.h>
int factorial(int n)
{
if(n == 1 || n == 0) // 递归终止条件
return 1;
else
return n * factorial(n - 1); // 递归调用
}
int main()
{
int n;
printf("请输入一个整数n:");
scanf("%d", &n);
printf("%d! = %d\n", n, factorial(n));
return 0;
}
```
这段代码中,factorial函数是递归实现的,当n等于1或0时,递归终止,返回1;否则,递归调用factorial函数,计算n * factorial(n-1)的值。在main函数中,读入一个整数n,然后输出n的阶乘。
c语言中的函数递归调用实现斐波那契数列
以下是C语言中使用递归调用实现斐波那契数列的代码:
```c
#include <stdio.h>
int Fibonacci(int n) {
if (n <= 1) {
return n;
}
return Fibonacci(n - 1) + Fibonacci(n - 2);
}
int main() {
int n = 0;
scanf("%d", &n);
int ret = Fibonacci(n);
printf("第%d个Fibonacci数列为%d\n", n, ret);
return 0;
}
```