Go语言实现Fibonacci数列 Go语言实现Fibonacci数列的方法
books1958 人气:0想了解Go语言实现Fibonacci数列的方法的相关内容吗,books1958在本文为您仔细讲解Go语言实现Fibonacci数列的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:Go语言,Fibonacci数列,方法,下面大家一起来学习吧。
本文实例讲述了Go语言实现Fibonacci数列的方法。分享给大家供大家参考。具体如下:
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)
}
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, 1
for i := 3; i <= index; i++ {
a, b = b, (a + b)
}
return a + b
}
if index == 1 || index == 2 {
return 1
}
a, b := 1, 1
for i := 3; i <= index; i++ {
a, b = b, (a + b)
}
return a + b
}
经过检验,使用非递归算法的效率要远远高于递归算法。
希望本文所述对大家的Go语言程序设计有所帮助。
加载全部内容