golang如何打印float64的整数部分_2020-08-10:如何不用加减乘除求浮点数的2倍值?...

福哥答案2020-08-10:

浮点数=符号位+阶码+尾数,阶码加1就是浮点数的2倍值。

代码用golang编写,如下:

package test33_addimport (    "fmt"    "math"    "testing")/*//https://www.bbsmax.com/A/6pdDX7gRdw///https://www.bbsmax.com/A/8Bz8GWVLdx///http://blog.sina.com.cn/s/blog_60670ed80100ro3l.html IEEE754标准的浮点数采用以下四种基本形式:1.单精度(32位):E=8位,M=23位;2.拓展单精度:E>=11位,M=31位;3.双精度(64位):E=11位,M=52位;4.拓展双精度:E>=15位,M>=63位。*///go test -v -test.run TestAddfunc TestAdd(t *testing.T) {    //9.625    //以上面的9.625为例,其规范浮点数表达为 1.001101*(2^3)    fmt.Println("根据符号位,阶数,尾数,打印9.625")    fmt.Println(GetFloat32(0, 0b10000010, 0b00110100000000000000000))    fmt.Println(GetFloat64(0, 0b10000000010, 0b0011010000000000000000000000000000000000000000000000))    fmt.Println("------------------------")    fmt.Println("打印2倍数:")    fmt.Println(GetTwoFloat32(1.1))    fmt.Println(GetTwoFloat64(1.1))    return}//循环,不用加号求两数之和func Add32(a uint32, b uint32) uint32 {    xor := uint32(0) //按位异或    c := uint32(1)   //按位与,左移一位。初始值为1,是为了进入for循环    for c != 0 {        xor = a ^ b    //按位异或        c = a & b << 1 //按位与,左移一位。初始值为了,是为了进入for循环        a = xor        b = c    }    return a}//递归,不用加号求两数之和func Add64(a uint64, b uint64) uint64 {    if b == 0 {        return a    } else {        return Add64(a^b, a&b<<1)    }}//根据符号位,阶码,尾数求浮点数func GetFloat64(s uint64, exp uint64, frac uint64) float64 {    s = s << 63    exp = exp & 0b00000111_11111111 << 52    frac = frac & 0b00000000_00001111_11111111_11111111_11111111_11111111_11111111_11111111    return math.Float64frombits(s | exp | frac)}//根据符号位,阶码,尾数求浮点数func GetFloat32(s uint32, exp uint32, frac uint32) float32 {    s = s << 31    exp = exp & 0b00000111_11111111 << 23    frac = frac & 0b00000000_01111111_11111111_11111111    return math.Float32frombits(s | exp | frac)}//根据浮点数求符号位,阶码,尾数func FromFloat64(f float64) (uint64, uint64, uint64) {    u := math.Float64bits(f)    return u >> 63, u >> 52 & 0b00000111_11111111, u & 0b00000000_00001111_11111111_11111111_11111111_11111111_11111111_11111111}//根据浮点数求符号位,阶码,尾数func FromFloat32(f float32) (uint32, uint32, uint32) {    u := math.Float32bits(f)    return u >> 31, u >> 23 & 0b00000111_11111111, u & 0b00000000_01111111_11111111_11111111}//单精度2倍func GetTwoFloat32(f float32) float32 {    s, exp, frac := FromFloat32(f)    if exp == 0 && frac == 0 { //0值        return 0    }    if exp == 0x11111111 { //超过边界        return f    }    if exp == 0x11111110 { //*2超过边界        return GetFloat32(s, 0x11111111, 0)    }    exp = Add32(exp, 1)    return GetFloat32(s, exp, frac)}//双精度2倍func GetTwoFloat64(f float64) float64 {    s, exp, frac := FromFloat64(f)    if exp == 0 && frac == 0 { //0值        return 0    }    if exp == 0x111_11111111 { //超过边界        return f    }    if exp == 0x111_11111110 { //*2超过边界        return GetFloat64(s, 0x111_11111111, 0)    }    exp = Add64(exp, 1)    return GetFloat64(s, exp, frac)}

敲命令 go test -v -test.run TestAdd 如下,结果如下:

4c6cc4dfdb359805da8385cc9a056988.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/245529.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql varchar 非空判断_工资从1万到3万,你还差mysql数据库优化之系列三

查询性能的优化优化查询分析的步骤:1.应用查询是否检索超过需要的数据2.mysql服务器是否在分析超过需要的数据正确使用索引:1.like语句操作一般不使用%或_开头例如: select * from tableName where name like %cn;只能使用like aaa%;2.组合索引例如索引index index_name (a, b,…

etl数据抽取工具_数据同步工具ETL、ELT傻傻分不清楚?3分钟看懂两者区别

什么是数据同步工具(ETL、ELT)数据同步工具ETL或者ELT的作用是将业务系统的数据经过抽取、清洗转换之后加载到数据仓库的过程&#xff0c;目的是将企业中的分散、零乱、标准不统一的数据整合到一起&#xff0c;为企业的决策提供分析依据。数据同步是大数据项目重要的一个环节。…

oracle数据库查表_Oracle面试问题-技术篇

这也许是你一直期待的文章&#xff0c;在关注这部分技术问题的同时&#xff0c;请务必阅读有关面试中有关个人的问题和解答。和猎萝卜小编来一起了解。这里的回答并不是十分全面&#xff0c;这些问题可以通过多个角度来进行解释&#xff0c;也许你不必在面试过程中给出完全详尽…

uniapp怎么调起摄像头拍视频_抖音视频怎么拍?我们总结了10个手机视频拍摄小技巧...

抖音的很多功能与小咖秀类似,但不同的是,抖音用户可以通过视频拍摄的快慢、视频编辑和特效等技术让作品更具创造性,而不是简单地对嘴型。抖音短视频的10个拍摄技巧,帮助你方便、快捷地制作出更加优质的短视频内容。1.远程控制暂停更方便抖音视频怎么拍&#xff1f;在拍摄时,如果…

jdk 安装_Jdk 安装使用教程

java 程序员的第一个程序 hello worldpublic class MyFirstJavaProgram {public static void main(String []args) {System.out.println("Hello World");}}1、下载jdk连接地址&#xff1a;https://docs.oracle.com/javase/8/docs/technotes/guides/install/install_o…

win10计算机管理字体糊,win10字体模糊如何解决

win10系统是一款优秀的消费级别的系统&#xff0c;深受大家广泛好评。但是有些网友在使用时也会出现一些问题&#xff0c;比如win10字体模糊。接下来&#xff0c;我就给大家介绍一下解决win10字体模糊的解决方法&#xff0c;赶紧来瞧瞧吧近来有不少网友询问win10字体模糊的解决…

蓝字冲销是什么意思_梦见上学 做梦梦到上学是什么意思 梦到上学有哪些预兆...

点击上方蓝字关注我们 查看更多梦见上学是什么意思 做梦梦到上学是什么意思 梦到上学有哪些预兆梦见上学 做梦梦到念书是什么意思 梦见上学代表什么意思预兆梦见上学&#xff0c;吉兆&#xff0c;生活会幸福快乐。梦见上学&#xff0c;可能是因为你近期的生活工作压力导致的&am…

ffmpeg如何在结尾添加帧_一种“视频帧对齐”的测试方案实践

点击蓝字?关注【测试先锋】&#xff0c;不再迷路&#xff01;一起成为互联网测试精英&#xff0c;前瞻测试技术&#xff5e;导语全参考清晰度测算的时候&#xff0c;输入两个视频帧序列&#xff0c;但是视频帧序列没有对齐&#xff0c;怎么知道丢了哪帧&#xff1f;又怎么知道…

java mongo分组统计_探秘 Dubbo 的度量统计基础设施 - Dubbo Metrics

对服务进行实时监控&#xff0c;了解服务当前的运行指标和健康状态&#xff0c;是微服务体系中不可或缺的环节。Metrics 作为微服务的重要组件&#xff0c;为服务的监控提供了全面的数据基础。近日&#xff0c;Dubbo Metrics 发布了2.0.1版本&#xff0c;本文将为您探秘 Dubbo …

python可以做运动控制卡吗_今天,终于明白了运动控制器和运动控制卡的区别

原标题&#xff1a;今天&#xff0c;终于明白了运动控制器和运动控制卡的区别 运动控制器是完整的、独立的硬件平台&#xff0c;运动控制卡则需要一个载体(一个系统运行平台&#xff0c;必须基于PC)。 一、从安装使用方式来看 运动控制卡&#xff0c;一般是PCI插槽的&#xff0…

电子计算机技能竞赛数据,2015年浙江省中等职业学校计算机应用技术专业学生职业技能大赛“计算机检测维修与数据恢复”赛项规程.doc...

2015年浙江省中等职业学校计算机应用技术专业学生职业技能大赛“计算机检测维修与数据恢复”赛项规程.doc还剩8页未读&#xff0c;继续阅读下载文档到电脑&#xff0c;马上远离加班熬夜&#xff01;亲&#xff0c;喜欢就下载吧&#xff0c;价低环保&#xff01;内容要点&#x…

设备的dpr_湘潭污水处理设备_处理污水设备生产厂

湘潭污水处理设备_处理污水设备生产厂?氮磷过度排放导致水体富营养化仍是全球关注的水污染热点问题, 而对于传统城市污水处理厂来说, 污水的深度脱氮除磷和同步达标排放仍是需要攻克的难点问题.传统脱氮除磷工艺存在脱氮与除磷对有限碳源的竞争、硝化反应产物对厌氧释磷的抑制…

奥鹏大工17秋计算机文化基础,大工17秋《数字电路与系统》在线作业100分满分答案...

大工17秋《数字电路与系统》在线作业1一、单选题&#xff1a;1.实现与运算功能的逻辑器件称为( )。 (满分:5)A.与门B.或门C.非门D.与或门正确答案:——A——2.变量每增加一个&#xff0c;其函数卡诺图的小格数就增加( )倍。 (满分:5)A.0.5B.1C.1.5D.2正确答…

git 32位_编译64位的BorderlessGaming

BorderlessGaming确实是一款很好用的工具,我主要用来把AS的模拟器全屏,来把Surface当安卓平板用,但是这东西的官方Release和Steam版本都是32位的,不过好在它开源,那就自己动手魔改一份吧首先把源码clone到本地git clone https://github.com/Codeusa/Borderless-Gaming.git用VS打…

十分钟计算机说课稿,足球十分钟说课稿范文(精选3篇)

足球十分钟说课稿范文(精选3篇)作为一位杰出的老师&#xff0c;常常要写一份优秀的说课稿&#xff0c;编写说课稿助于积累教学经验&#xff0c;不断提高教学质量。怎样写说课稿才更能起到其作用呢&#xff1f;以下是小编为大家整理的足球十分钟说课稿范文&#xff0c;欢迎阅读与…

主叫号码未显示怎么设置_微信未授权抖音,应该怎么设置?

微信未授权抖音&#xff0c;应该如何设置&#xff1f;这篇文章&#xff0c;笔点酷玩手把手教你完成。首先我们要明确&#xff0c;这种设置属于将微信账户的授权给第三方&#xff0c;用于统一身份的登录&#xff0c;需要用户自己手动授权“绑定”&#xff0c;也可以随时进行解绑…

eclipse没有日志_「开源资讯」Jboot v3.3.6 发布,更强大的控制台请求日志

Jboot 是一个基于 JFinal、JFinal-Undertow、Dubbo、Seata、Sentinel、ShardingSphere、Nacos 等开发的微服务框架&#xff0c;帮助开发者降低微服务开发门槛。同时完美支持在 idea、eclipse 下多 maven 模块&#xff0c;对 java 代码、html、css、js 等资源文件进行热加载。爽…

计算机地址码特点,电脑摇头灯的地址码的设定问题你必须要注意的

原标题&#xff1a;电脑摇头灯的地址码的设定问题你必须要注意的在上一期文章中&#xff0c;我们广州舞台灯光设备批发厂家歌斯达为大家分享了电脑摇头灯的供电电源问题和信号线问题之后&#xff0c;这一次的文章&#xff0c;我们将继续为大家分享更多关于电脑摇头光束灯的相关…

java项目经验怎么写_模具工简历项目经验怎么写

项目经验(案例一)项目时间&#xff1a;2015-04 - 2015-05项目名称&#xff1a;活动策划项目描述&#xff1a;项目介绍通过策划一系列的活动来提高家具店的知名度&#xff0c;从而拔高家具店正式开业后的销售额。我的职责协助经理完成开业前后的活动策划以及提出个人见解&#x…

freemaker if 多个条件_第4天|14天搞定Vue3.0,条件渲染和template

所谓的条件&#xff0c;指的就是满足什么条件&#xff0c;允许做什么事&#xff0c;不满足时&#xff0c;是不允许做的。如共享单车&#xff0c;规定满12周岁或以上才可以骑行&#xff0c;没满的则不被允许。学每门编程语言&#xff0c;条件语句都是必须熟练掌握的&#xff0c;…