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,一经查实,立即删除!

相关文章

五年级数学上册用计算机探索规律,人教版小学五年级数学上册《用计算器探索规律》课后反思...

当前,新课程改革强调学生学习方式的转变.高效课堂是课程改革过程中有效学习方式之一.在高效课堂中,孩子们能发挥自己潜能、展示自己的才能,提高了孩子们的学习兴趣.如何让高效课堂焕发光彩能&#xff1f;一、合理分组,恰当分工合理分组是高效课堂顺利进行的前提.在以前的学习过…

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;为企业的决策提供分析依据。数据同步是大数据项目重要的一个环节。…

浙江等高等学校计算机,2010年浙江省高等学校计算机等级考试

2010年上半年浙江省高等学校计算机等级考试二级C程序设计试卷一、程序阅读与填空(24小题&#xff0c;每小题3分同&#xff0c;共72分)1&#xff0e;阅读下列程序说明和程序&#xff0c;在每小题提供的若干可选答案中&#xff0c;挑选一个正确答案。【程序说明】输入一个正整数&…

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

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

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

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

计算机的两个基本能力是存储程序,【2012年职称计算机模拟题(55)】- 环球网校...

15.简述计算机的存储程序原理$lesson$答&#xff1a;计算机的工作方式取决于它的两个基本能力&#xff0c;A.是能够存储程序;B.是能够自动执行程序。计算机利用存储器(内存)来存放所要执行的程序&#xff0c;而CPU可以依次从存储器中取出程序的每一条指令&#xff0c;并加以分析…

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;又怎么知道…

2021盐城中考有计算机考试吗,2021盐城中考总分满分是多少?各科目分值设置

2021盐城中考总分满分是多少&#xff1f;各科目分值设置三、考试科目盐城市2021年初中毕业与升学考试(简称“中考”)模式为“学业水平考试实验实践技能考查综合素质评价”。学业水平考试和实验实践技能考查的评价标准由市教科院制定发布。1. 学业水平考试2021年中考学业水平考试…

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_湘潭污水处理设备_处理污水设备生产厂

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

python 总结_python总结

Python基础教程 学习总结 1. 导入模块 “模块.函数”&#xff08;优先使用&#xff09; importmath math.sqrt(9) 在确定不会导入多个同名函数时&#xff0c;可以使用 “from 模块 import 函数” 方式 from math importsqrt sqrt(9) 还可以使用变量来引用函数 foomath.sqrt foo…

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

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

我的世界java版和基岩版对比_我的世界:基岩版比Java多出的七个特性,都听过的非老mc莫属了!...

你玩的是java版还是基岩版呢&#xff1f;这两个版本是我们经常使用的版本&#xff0c;看似一模一样&#xff0c;其实在细节上也有些一些差别。对比Java版&#xff0c;基岩版多出了这七个特性。今天我们就来聊一聊基岩版当中特有的七个特性&#xff0c;堪称隐藏的彩蛋&#xff0…

git 32位_编译64位的BorderlessGaming

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