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
超出了它的符文(字符)范围,而 rune
是 int32
的别名,因此字符结果的一部分将打印为单独的数字,它们之间没有空格(因为您使用 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))
}
我想在 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
超出了它的符文(字符)范围,而 rune
是 int32
的别名,因此字符结果的一部分将打印为单独的数字,它们之间没有空格(因为您使用 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))
}