Go语言实现Fibonacci数列的两个算法(使用递归和不使用递归)

来源:互联网 发布:windows程序设计中文版 编辑:程序博客网 时间:2024/06/05 14:32

Fibonacci数列:1,1,2,3,5,8,13,21,,, (即从第三项起,每一项的值都等于前两项之后)

第一种,使用递归:

func fibonacci(a int) int {if a == 1 || a == 2 {return 1}return fibonacci(a-1) + fibonacci(a-2)}

第二种,不使用递归:

func fibonacci_version2(index int) int {if index == 1 || index == 2 {return 1}a, b := 1, 1for i := 3; i <= index; i++ {a, b = b, (a + b)}return a + b}

经过检验,使用非递归算法的效率要远远高于递归算法

0 0