Go语言实现Fibonacci数列的方法
本文实例讲述了Go语言实现Fibonacci数列的方法。分享给大家供大家参考。具体如下:
Fibonacci数列:1,1,2,3,5,8,13,21,,,(即从第三项起,每一项的值都等于前两项之后)
第一种,使用递归:
funcfibonacci(aint)int{
ifa==1||a==2{
return1
}
returnfibonacci(a-1)+fibonacci(a-2)
}
第二种,不使用递归:
funcfibonacci_version2(indexint)int{
ifindex==1||index==2{
return1
}
a,b:=1,1
fori:=3;i<=index;i++{
a,b=b,(a+b)
}
returna+b
}
经过检验,使用非递归算法的效率要远远高于递归算法。
希望本文所述对大家的Go语言程序设计有所帮助。