首页 >Java >java教程 >如何在 Java 中以精确的格式打印双精度数,消除不必要的尾随零?

如何在 Java 中以精确的格式打印双精度数,消除不必要的尾随零?

Barbara Streisand
Barbara Streisand原创
2024-12-31 13:41:11620浏览

How Can I Print Doubles in Java with Precise Formatting, Eliminating Unnecessary Trailing Zeros?

在 Java 中精确打印浮点数

鉴于 64 位双精度数能够精确表示一定范围内的整数,在打印混合整数和双值。虽然 String.format("%f") 提供了紧密格式,但它为小值添加了不必要的尾随零。

寻求解决方案:

目标是打印整数值存储为不带小数零的双精度数,同时保持实际双精度数的高精度。例如,考虑到这些输入:

  • 232.00000000
  • 0.18000000000
  • 1237875192 .0
  • 4.5800000000
  • 0.00000000
  • 1.23450000

期望的输出将为:

  • 232
  • 0.18
  • 1237875192
  • 4.58
  • 0
  • 1.2345

高效格式:

为了优化格式,我们可以利用整数值可以精确表示为 64 位双精度数这一事实。以下 Java 代码片段无需借助性能密集型字符串操作即可实现此目的:

public static String fmt(double d) {
    if (d == (long) d)
        return String.format("%d", (long) d);
    else
        return String.format("%s", d);
}

说明:

  • 用于可以准确表示的整数值作为双精度数,代码将它们转换为长整型并使用 %d 对其进行格式化。这消除了不必要的尾随零。
  • 对于非整数值,代码使用 %s 以最小精度保留原始双精度值。

结果:

应用于示例输入时,输出与所需的格式匹配:

232
0.18
1237875192
4.58
0
1.2345

以上是如何在 Java 中以精确的格式打印双精度数,消除不必要的尾随零?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn