递归函数编写斐波那契前18项
时间: 2025-02-23 18:34:13 AIGC 浏览: 34
递归函数是一种通过自身调用来解决问题的方法,常用于解决可以分解成相似子问题的问题。对于斐波那契数列,它是一个典型的递归问题,每个数字是前两个数字的和。下面是用Python编写的一个递归函数,计算并打印出斐波那契数列的前18项:
```python
def fibonacci(n):
if n <= 0:
return "输入值错误"
elif n == 1:
return [0]
elif n == 2:
return [0, 1]
else:
fib_list = fibonacci(n - 1)
fib_list.append(fib_list[-1] + fib_list[-2])
return fib_list
# 计算并打印斐波那契数列的前18项
fibonacci_sequence = fibonacci(18)
for i in range(len(fibonacci_sequence)):
print(f"第{i+1}项:{fibonacci_sequence[i]}")
相关问题
递归函数编写斐波那契
斐波那契数列是指:0、1、1、2、3、5、8、13、21、34、……,在数学上,斐波那契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*)。
以下是使用递归函数编写斐波那契数列的Python代码:
```python
def feibo(n):
if n == 0:
return 0
elif n == 1:
return 1
else:
return feibo(n-1) + feibo(n-2)
n = int(input("请输入n的值:"))
print(feibo(n))
```
在这个代码中,我们定义了一个名为`feibo`的递归函数,它接受一个整数参数`n`,并返回斐波那契数列中第`n`项的值。如果`n`等于0或1,则直接返回0或1。否则,递归调用`feibo(n-1)`和`feibo(n-2)`,并将它们的和作为结果返回。
在主函数中,我们首先从用户那里获取输入的`n`值,然后调用`feibo`函数并打印结果。
用递归函数编写斐波那契数列
好的,斐波那契数列的递推式为:F(n) = F(n-1) + F(n-2),其中 F(0) = 0, F(1) = 1。
以下是用递归函数实现斐波那契数列的代码:
```python
def fibonacci(n):
if n <= 1:
return n
else:
return fibonacci(n-1) + fibonacci(n-2)
```
在这个函数中,我们首先判断 n 是否小于等于 1,如果是的话就返回 n。如果不是,就递归地调用 fibonacci 函数,计算 F(n-1) 和 F(n-2),并将它们相加返回。
这个实现方式的缺点是对于较大的 n 值,递归调用会造成大量的重复计算,导致效率较低。因此,对于大规模的斐波那契数列计算,推荐使用其他更加高效的方法。
阅读全文
相关推荐


















