栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

可以将每个浮点数精确表示为两倍吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

可以将每个浮点数精确表示为两倍吗?

是。

通过列举所有可能的情况来证明:

public class TestDoubleFloat  {    public static void main(String[] args) {        for (long i = Integer.MIN_VALUE; i <= Integer.MAX_VALUE; i++) { float f1 = Float.intBitsToFloat((int) i); double d = (double) f1; float f2 = (float) d; if (f1 != f2) {     if (Float.isNaN(f1) && Float.isNaN(f2)) {         continue; // ok, NaN     }     fail("oops: " + f1 + " != " + f2); }        }    }}

在我的机器上在12秒内完成。32位 很小



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/596117.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号