doucha4054 2019-03-01 19:25
浏览 128

如何在Go中获得5000阶乘

I would like to calculate a factorial of 5000 in Go but got 0 as a result because the result is bigger than a uint64. However, I was able to do it in Node.js by using

const BigNumber = require('big-number').

Is there an equivalent in Go?

What I did was:

func RecursiveFactorial(number int) big.Int {
    if number >= 1 {
        return big.Int{(number) * RecursiveFactorial(number-1)
    } else {
        return 1
    }
}
  • 写回答

2条回答 默认 最新

  • doudou7361 2019-03-01 21:24
    关注

    In Go, use the math/big package.

    For example,

    // OEIS: A000142: Factorial numbers: n! = 1*2*3*4*...*n.
    // https://oeis.org/A000045
    
    package main
    
    import (
        "fmt"
        "math/big"
    )
    
    func factorial(x *big.Int) *big.Int {
        n := big.NewInt(1)
        if x.Cmp(big.NewInt(0)) == 0 {
            return n
        }
        return n.Mul(x, factorial(n.Sub(x, n)))
    }
    
    func main() {
        fmt.Println(factorial(big.NewInt(5000)))
    }
    

    Playground: https://play.golang.org/p/53TmmygltkR

    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码