Ksh*_*kal 0 string math go bigint
我想在 golang 中计算 100 阶乘。这是我正在使用的代码。
var fact big.Int
fact.MulRange(1, 100)
Run Code Online (Sandbox Code Playgroud)
打印输出给出
30414093201713378043612608166064768844377641568960512000000000000
但是谷歌搜索100!给出9.332622e+157。我想这可能是因为我使用的数据类型(或者可能不是)。我该如何解决?提前致谢。
编辑:所以我在 go playground 中运行了这段代码,它给出了正确的答案。这是由于我的 PC 上的限制吗?另外,当我将其转换为字符串并对其进行迭代时,它会显示不同的数字
str := fact.String()
for _,val := range str{
fmt.Print(val)
}
Run Code Online (Sandbox Code Playgroud)
这是所有的代码
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)
}
Run Code Online (Sandbox Code Playgroud)
这是 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
Run Code Online (Sandbox Code Playgroud)
和 go 版本:go 版本 go1.10.1 windows/amd64
要打印一个string值,只需将其按原样传递给fmt.Println():
str := fact.String()
fmt.Println(str)
Run Code Online (Sandbox Code Playgroud)
另请注意,您不需要调用它的String()方法,该fmt包会为您执行此操作。但是如果你只是传递fact给它,因为Int.String()有指针接收器,所以你必须传递一个指针给它:
fmt.Println(&fact)
Run Code Online (Sandbox Code Playgroud)
或者先声明并使用*big.Int,然后就可以fact简单的通过打印:
var fact = new(big.Int)
fact.MulRange(1, 100)
fmt.Println(fact)
Run Code Online (Sandbox Code Playgroud)
实际上,由于所有的方法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)
Run Code Online (Sandbox Code Playgroud)
这将打印(在Go Playground 上显示):
93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000
648
Run Code Online (Sandbox Code Playgroud)