用C语言编写递归函数,实现斐波那契数列前20项的和。
时间: 2024-03-14 10:43:11 浏览: 72
好的,下面是C语言实现斐波那契数列前20项的和的递归函数代码:
```c
#include <stdio.h>
int fibonacci(int n);
int main() {
int sum = 0;
for (int i = 0; i < 20; i++) {
sum += fibonacci(i);
}
printf("斐波那契数列前20项的和为:%d\n", sum);
return 0;
}
int fibonacci(int n) {
if (n == 0 || n == 1) {
return n;
}
else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
```
在主函数中,我们使用一个循环计算前20项的斐波那契数列元素的和,并将其存储在变量`sum`中。递归函数`fibonacci`用于计算斐波那契数列中第n个元素的值,如果n等于0或1,则直接返回n,否则递归计算`n-1`和`n-2`两个元素的和并返回结果。最终在主函数中输出斐波那契数列前20项的和。
相关问题
用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 = 10; // 前十项
// 输出前十项
for (int i = 0; i < n; i++) {
printf("%d ", fibonacci(i));
}
return 0;
}
```
运行以上代码,将会输出斐波那契数列的前十项:
```
0 1 1 2 3 5 8 13 21 34
```
在代码中,我们定义了一个递归函数 `fibonacci`,它接受一个整数 `n` 作为参数,并返回斐波那契数列的第 `n` 项。如果 `n` 小于等于 1,则直接返回 `n`。否则,递归地调用函数 `fibonacci(n-1)` 和 `fibonacci(n-2)`,然后将它们的结果相加返回。
在 `main` 函数中,我们使用一个循环调用 `fibonacci` 函数来输出斐波那契数列的前十项。每次循环,我们将当前的索引值作为参数传递给 `fibonacci` 函数,并将结果打印出来。
c语言用递归方法实现斐波那契数列
C语言可以使用递归方法实现斐波那契数列。递归方法的实现比较简单,只需要判断n是否小于等于2,如果是则返回1,否则返回fib(n-1)+fib(n-2)。下面是一个示例代码:
```
#include <stdio.h>
int fib(int n) {
if (n <= 2) {
return 1;
}
return fib(n - 1) + fib(n - 2);
}
int main() {
int n;
scanf("%d", &n);
int ret = fib(n);
printf("%d\n", ret);
return 0;
}
```
在这个示例代码中,我们定义了一个fib函数,用于计算斐波那契数列的第n项。在函数中,我们首先判断n是否小于等于2,如果是则返回1,否则返回fib(n-1)+fib(n-2)。在main函数中,我们读入n的值,然后调用fib函数计算第n项斐波那契数,并输出结果。
阅读全文