golang 中的 100 阶乘

100 factorial in golang

我想在 golang 中计算 100 个阶乘。这是我正在使用的代码。

var fact big.Int
fact.MulRange(1, 100)

打印输出

30414093201713378043612608166064768844377641568960512000000000000

但是谷歌搜索 100!给出 9.332622e+157。我认为这可能是因为我正在使用(或可能不是)的数据类型。我该如何解决?提前致谢。

编辑: 所以我在 go playground 中 运行 这段代码给出了正确的答案。这是由于我的 PC 的限制吗?另外,当我将它转换为字符串并遍历它时,它显示不同的数字

str := fact.String()
for _,val := range str{
    fmt.Print(val)
}

这是全部代码

package main

import (
    "fmt"
    "math/big"
)

func main() {
    var fact big.Int
    fact.MulRange(1, 100)
    fmt.Println(fact)
    n := fact.String()
    fmt.Println(n) //printing 100!
    sum := 0
    for _, i := range n {
        sum += int(i) //sum of each digits in 100!
    }
    fmt.Println(sum)
}

这是 go env 显示的内容:

set GOARCH=amd64
set GOBIN=
set GOCACHE=C:\Users\user\AppData\Local\go-build
set GOEXE=.exe
set GOHOSTARCH=amd64
set GOHOSTOS=windows
set GOOS=windows
set GOPATH=C:\Users\user\go
set GORACE=
set GOROOT=C:\Go
set GOTMPDIR=
set GOTOOLDIR=C:\Go\pkg\tool\windows_amd64
set GCCGO=gccgo
set CC=gcc
set CXX=g++
set CGO_ENABLED=1
set CGO_CFLAGS=-g -O2
set CGO_CPPFLAGS=
set CGO_CXXFLAGS=-g -O2
set CGO_FFLAGS=-g -O2
set CGO_LDFLAGS=-g -O2
set PKG_CONFIG=pkg-config
set GOGCCFLAGS=-m64 -mthreads -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fdebug-prefix-map=C:\Users\user\AppData\Local\Temp\go-build839268890=/tmp/go-build -gno-record-gcc-switches

go版本:go版本go1.10.1windows/amd64

要打印 string 值,只需按原样将其传递给 fmt.Println():

str := fact.String()
fmt.Println(str)

另请注意,您无需调用其String()方法,fmt package will do that for you. But not if you just pass fact to it, because Int.String()具有指针接收器,因此您必须将指针传递给它:

fmt.Println(&fact)

或者首先声明并使用*big.Int,然后你可以通过fact简单地打印:

var fact = new(big.Int)
fact.MulRange(1, 100)
fmt.Println(fact)

实际上,由于 big.Int 的所有方法都有指针接收器,因此您应该始终声明和使用 big.Int 的指针以避免意外。

注:

您的原始代码没有打印您想要的内容,因为字符串上的 for range 超出了它的符文(字符)范围,而 runeint32 的别名,因此字符结果的一部分将打印为单独的数字,它们之间没有空格(因为您使用 fmt.Print() 调用打印每个数字)。

出于同样的原因,要计算数字的总和,您必须将符文转换为它们所代表的数字的数值。为此,您可以简单地使用 digit - '0':

str := fact.String()
sum := 0
for _, val := range str {
    sum += int(val - '0')
}
fmt.Println(sum)

这将打印(在 Go Playground 上打印):

93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000
648

信用来源:quora

你可以这样处理

所以你可以计算日志的总和而不是将所有数字相乘然后 () 结果得到! .

ln(!)=!

package main

import (
    "fmt"
    "math"
)

func main() {
    fmt.Println("Hello, playground")
    fact(100)
}
func fact(n float64){
var sum float64
sum = 0
var i float64
for i= 1;i<=n;i++{
    sum = sum+math.Log(i)

}
fmt.Println(math.Exp(sum))

}

https://play.golang.org/p/74LPoIifNZ-