dongshi1934 2018-02-16 13:42
浏览 52
已采纳

如何在旅途中很好地显示浮点数

I want to be able to display very large floating point numbers created with math/big.

  • if there are no decimals, no .000 should be added
  • only add the necessary number of decimals (display 1.1234 not 1.123400)
  • great precision (tens of exact decimals)

https://play.golang.org/p/CulS5wXxzGq

coef := new(big.Float).SetPrec(4096)
coef.SetString("1000000000000000")
a := new(big.Float).SetPrec(4096)
a.SetString("1")
a.Quo(a, coef)
fmt.Printf("%.100g
", a)
// 1e-15
// was expecting: 0.000000000000001

b := new(big.Float).SetPrec(4096)
b.SetString("1234.00")
fmt.Printf("%.100g
", b)
// 1234.00
// looks good

c := new(big.Float).SetPrec(4096)
c.SetString("1234.001000")
fmt.Printf("%.100g
", c)
// 1234.001000
// looks good
  • 写回答

1条回答 默认 最新

  • dongtang1910 2018-02-16 14:06
    关注

    There is a Text() method for big.Float that I think does what you want. If passed a negative precision, it will use as many digits as necessary to represent the value, but no more. Try:

    func format(x *big.Float) string {
        return x.Text('f', -1)
    }
    

    That will give you:

    0.000000000000001
    1234
    1234.001
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

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