用递归写一个斐波那契数列,c语言。
时间: 2023-05-27 14:02:24 浏览: 69
```
#include <stdio.h>
int fibonacci(int n)
{
if(n == 0 || n == 1)
return n;
else
return fibonacci(n-1) + fibonacci(n-2);
}
int main()
{
int n, i;
printf("输入要输出的斐波那契数列的长度:");
scanf("%d", &n);
printf("斐波那契数列:\n");
for(i=0; i<n; i++)
printf("%d ", fibonacci(i));
return 0;
}
```
运行结果:
输入要输出的斐波那契数列的长度:10
斐波那契数列:
0 1 1 2 3 5 8 13 21 34
相关问题
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;
printf("请输入斐波那契数列的项数:");
scanf("%d", &n);
printf("斐波那契数列的前 %d 项为:\n", n);
for (int i = 0; i < n; i++) {
printf("%d ", fibonacci(i));
}
return 0;
}
```
这段代码中,`fibonacci` 函数使用递归的方式计算斐波那契数列的第 `n` 项。当 `n` 小于等于1时,直接返回 `n`。当 `n` 大于1时,递归调用 `fibonacci` 函数计算第 `n-1` 项和第 `n-2` 项的和作为结果返回。
在 `main` 函数中,我们首先获取用户输入的项数,然后使用循环调用 `fibonacci` 函数并打印出斐波那契数列的前 `n` 项。
希望对你有帮助!如果还有其他问题,请随时提问。
递归实现n个斐波那契数列c语言
可以使用递归来实现斐波那契数列,C语言代码如下:
```c
#include <stdio.h>
int fibonacci(int n) {
if (n <= 1) {
return n;
}
else {
return fibonacci(n-1) + fibonacci(n-2);
}
}
int main() {
int i;
for (i = 0; i < 10; i++) {
printf("%d ", fibonacci(i));
}
return 0;
}
```
与前面Python的代码类似,我们首先判断了n是否小于等于1,如果是,直接返回n。然后,如果n大于1,我们就递归地调用函数,计算出n-1和n-2的斐波那契数列值,然后将它们相加并返回结果。注意,在C语言中,要使用printf函数来打印输出结果。
需要注意,这种递归方法虽然简单易懂,但对于大的n可能会非常慢,因为它的时间复杂度是指数级别的。实际应用中,我们应该尽量避免使用递归来实现斐波那契数列。