【发布时间】:2012-06-30 00:38:39
【问题描述】:
我正在尝试实现这段代码:
func factorial(x int) (result int) {
if x == 0 {
result = 1;
} else {
result = x * factorial(x - 1);
}
return;
}
作为 big.Int 以使其对较大的 x 值有效。
以下是 fmt.Println(factorial(r)) 的返回值为 0
7的阶乘应该是5040?
关于我做错了什么有什么想法吗?
package main
import "fmt"
import "math/big"
func main() {
fmt.Println("Hello, playground")
//n := big.NewInt(40)
r := big.NewInt(7)
fmt.Println(factorial(r))
}
func factorial(n *big.Int) (result *big.Int) {
//fmt.Println("n = ", n)
b := big.NewInt(0)
c := big.NewInt(1)
if n.Cmp(b) == -1 {
result = big.NewInt(1)
}
if n.Cmp(b) == 0 {
result = big.NewInt(1)
} else {
// return n * factorial(n - 1);
fmt.Println("n = ", n)
result = n.Mul(n, factorial(n.Sub(n, c)))
}
return result
}
go 游乐场上的此代码:http://play.golang.org/p/yNlioSdxi4
【问题讨论】:
标签: go