递归函数

一个函数调用自己,就叫做递归
递归的设计原则:

1.一个大的问题能够分解成相似的小问题
2.定义好出口条件

举个简单的例子

package main
import(
    "fmt"
    "time"
)

func main(){
    fmt.Println("hello world")
    time.Sleep(time.Second*2)
    main()
}

n的阶乘

package main

import(
    "fmt"   
)

func calc(n int) int{
    if n == 1 {
        return 1
    }
    return calc(n-1)* n
}
func main(){
    n := calc(5)
    fmt.Println(n)
}

输出:120

斐波那契数

package main

import(
    "fmt"
)

func fab(n int) int{
    if n<=1{
        return 1
    }
    return fab(n - 1) + fab(n - 2)    
}

func main(){
    for i:=0 ; i<10; i++{
        n:=fab(i)
        fmt.Println(n)
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容