利用函数递归实现斐波那契数列前24项。
时间: 2024-09-19 21:01:26 浏览: 41
斐波那契数列是一个经典的数列,其中每个数字都是前两个数字之和,通常从0和1开始。利用函数递归来计算斐波那契数列非常直观,我们可以创建一个函数,这个函数会检查输入的索引,如果索引小于等于1,返回对应的常数值;否则返回前两个数相加的结果。
下面是一个简单的Python代码示例,展示了如何递归地计算斐波那契数列的前24项:
```python
def fibonacci(n):
if n <= 0:
return "Invalid input"
elif n == 1 or n == 2:
return [0, 1]
else:
fib_sequence = fibonacci(n - 1) + [fibonacci(n - 2)[1]]
return fib_sequence
# 计算并打印前24项
fibonacci_sequence = fibonacci(24)
print(fibonacci_sequence)
```
当你运行这段代码时,它将输出斐波那契数列的前24项。需要注意的是,递归方式虽然简单,但对于较大的n值来说,效率较低,因为它会重复计算很多已经计算过的项。
相关问题
使用函数递归实现Fibonacci数列的输出
以下是使用函数递归实现Fibonacci数列的Python代码:
```python
def fibonacci(n):
if n <= 1:
return n
else:
return fibonacci(n-1) + fibonacci(n-2)
# 测试
for i in range(10):
print(fibonacci(i))
```
输出结果为:
```
0
1
1
2
3
5
8
13
21
34
```
该代码中,`fibonacci()`函数接受一个整数参数`n`,表示要输出Fibonacci数列的前n项。在函数中,如果`n`小于等于1,则返回n;否则,递归调用`fibonacci(n-1)`和`fibonacci(n-2)`,并将它们的返回值相加作为当前项的值。最后,遍历前n项,分别输出它们的值。
C语言编写递归函数,实现斐波那契数列前20项的和。
下面是使用递归函数实现斐波那契数列前20项的和的C语言代码:
```c
#include <stdio.h>
int fibonacci(int n);
int main() {
int sum = 0;
for (int i = 1; i <= 20; i++) {
sum += fibonacci(i);
}
printf("斐波那契数列前20项的和为:%d\n", sum);
return 0;
}
int fibonacci(int n) {
if (n == 1 || n == 2) {
return 1;
} else {
return fibonacci(n - 1) + fibonacci(n - 2);
}
}
```
在这段代码中,我们定义了一个 `fibonacci` 函数,用于计算斐波那契数列中第 `n` 项的值。然后在 `main` 函数中,我们使用一个循环来计算前20项的和,并输出结果。
阅读全文