首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Go中的浮动精度

Go中的浮动精度
EN

Stack Overflow用户
提问于 2015-08-22 23:34:10
回答 1查看 1.7K关注 0票数 1

这个问题是a previous question I asked的后续问题。我收到的答案建议我使用Go math.Big库。在这个问题中,我使用了库,但不幸的是收效甚微。

我正在尝试使用Binet公式来计算fib(100)。我正在使用Go的Big.Float,但没有成功。我得到了小数点后10位的准确度。请给我建议。

我正在努力避免循环/递归,因为我认为这些方法不会很好地扩展。因此我尝试利用Binet的公式

//当前随着输入的增加而产生不准确的结果。

代码语言:javascript
运行
复制
package main

import (
    "fmt"
    "math/big"
    "math"
    "strconv"
)

func fib(n int) float64  {
    var sroot5 = new(big.Float).SetPrec(200).SetFloat64(2.236067977499789696409173668731276235440618359611525724270897)
    var phi = new(big.Float).SetPrec(200).SetFloat64(1.61803398874989484820458683436563811772030917980576286213544862)
    var minusPhi = new(big.Float).SetPrec(200).SetFloat64(-0.61803398874989484820458683436563811772030917980576)

    var fltP float64;
    fltP, _ = phi.Float64()

    var fltN float64;
    fltN, _ = minusPhi.Float64()

    var denom float64
    denom, _ = sroot5.Float64()

    // Magic fib formula (Binet) is:
    // (Phi ^ n - (-phi ^ n)) / sqrt(5)

    z := (math.Pow(fltP, float64(n)) - math.Pow(fltN, float64(n))) / denom 

    return math.Ceil(z) 

}

func main() {

    fib(100)

    fmt.Println(strconv.FormatFloat(fib(100), 'f', 0, 64))
    fmt.Println("true answer of fib(100) should be -> 354224848179261915075")

}
EN

回答 1

Stack Overflow用户

发布于 2015-08-23 00:00:06

您正在使用IEEE 754 64-bit floating point

在Go中,要精确计算fib(100),您可以简单地说:

代码语言:javascript
运行
复制
package main

import (
    "fmt"
    "math/big"
)

func fib(n int) *big.Int {
    f := big.NewInt(0)
    a, b := big.NewInt(0), big.NewInt(1)
    for i := 0; i <= n; i++ {
        f.Set(a)
        a.Set(b)
        b.Add(f, b)
    }
    return f
}

func main() {
    fmt.Println(fib(100))
}

输出:

代码语言:javascript
运行
复制
354224848179261915075
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32157833

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档