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)  

}

第二种,不使用递归:

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  

}

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

希望本文所述对大家的Go语言程序设计有所帮助。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。