Go支援遞回函式。 這裡是一個經典的階乘例子。
所有的範例程式碼,都放在
F:\worksp\golang
目錄下。安裝Go程式設計環境請參考:/2/23/798.html
這個fact()
函式實際上是呼叫它自己本身,直到它達到fact(0)
時結果退出。
closures.go
的完整程式碼如下所示 -
package main
import "fmt"
// This `fact` function calls itself until it reaches the
// base case of `fact(0)`.
func fact(n int) int {
if n == 0 {
return 1
}
return n * fact(n-1)
}
func main() {
fmt.Println(fact(7))
}
執行上面程式碼,將得到以下輸出結果 -
F:\worksp\golang>go run recursion.go
5040