十进制小数 与 二进制小数 互转

1、十进制小数 转 二进制小数

公式
  1. 小数 * 2得到n1, 将n1的整数作为二进制数第一位;
  2. n1的小数 * 2得到n2, 将n2的整数作为二进制数第二位;
  3. n2的小数 * 2得到n3, 将n3的整数作为二进制数第三位;
  4. … 重复以上步骤,直到小数部分为0或者达到指定的精度即可。
例子一: 十进制0.1转二进制

0.1 * 2 = 0.2 →取整数部分0
0.2 * 2 = 0.4 →取整数部分0
0.4 * 2 = 0.8 →取整数部分0
0.8 * 2 = 1.6 →取整数部分1
0.6 * 2 = 1.2 →取整数部分1
0.2 * 2 = 0.4 →取整数部分0
0.4 * 2 = 0.8 →取整数部分0
0.8 * 2 = 1.6 →取整数部分1
0.6 * 2 = 1.2 →取整数部分1

可以看到0.1转2进制不管怎么乘2结果小数位不可能为0,是一个无限循环小数,只能截取一部分。
我们再将获得的整数部分组合起来
二进制为:0.00011001100110011001101(截取23位)

例子二: 十进制0.2转二进制

0.2 * 2 = 0.4 →取整数部分0
0.4 * 2 = 0.8 →取整数部分0
0.8 * 2 = 1.6 →取整数部分1
0.6 * 2 = 1.2 →取整数部分1
0.2 * 2 = 0.4 →取整数部分0
0.4 * 2 = 0.8 →取整数部分0
0.8 * 2 = 1.6 →取整数部分1
0.6 * 2 = 1.2 →取整数部分1

0.2转2进制同样是一个无限循环小数,只能截取一部分。
二进制为:0.00110011001100110011011(截取23位)

例子三: 十进制0.3转二进制

0.3 * 2 = 0.6 →取整数部分0
0.6 * 2 = 1.2 →取整数部分1
0.2 * 2 = 0.4 →取整数部分0
0.4 * 2 = 0.8 →取整数部分0
0.8 * 2 = 1.6 →取整数部分1
0.6 * 2 = 1.2 →取整数部分1

0.3转2进制同样是一个无限循环小数,只能截取一部分。
二进制为:0.01001100110011001100110(截取23位)

例子三: 十进制0.5转二进制

0.5 * 2 = 1.0 →取整数部分1

二进制为:0.1

我们可以看出,0.1和0.2转二进制的时候就已经失去精度了。

截取无限循环数时,向上取舍。

截取n位时,判断(n+1)位是否为1,为1则n位+1,为0直接舍去。

0.1100截取为3位,第4位为0,直接舍去。
0.1001截取为3位,第4位为1,第3位+1 ----> 0.101


2、二进制小数 转 十进制小数

小数点后开始,依次乘以2的负一次方,2的负二次方,2的负三次方…

公式:
  1. 小数第 1 位 ∗ 2 − 1 小数第1位 * 2^{-1} 小数第121
  2. 小数第 2 位 ∗ 2 − 2 小数第2位 * 2^{-2} 小数第222
  3. 小数第 3 位 ∗ 2 − 3 小数第3位 * 2^{-3} 小数第323
  4. 小数第 4 位 ∗ 2 − 4 小数第4位 * 2^{-4} 小数第424
  5. 最后将所有计算结果求和,就能得到十进制小数了。
例子一: 二进制0.1转十进制

0.1 ∗ 2 − 1 0.1*2^{-1} 0.121 = 0.5

例子二: 二进制0.01001100110011001100110转十进制

0 ∗ 2 1 + 1 ∗ 2 − 2 + 0 ∗ 2 − 3 + 0 ∗ 2 − 4 + 1 ∗ 2 − 5 + 1 ∗ 2 − 6 + 0 ∗ 2 − 7 + 0 ∗ 2 − 8 + 1 ∗ 2 − 9 + 1 ∗ 2 − 10 + 0 ∗ 2 − 11 + 0 ∗ 2 − 12 + 1 ∗ 2 − 13 + 1 ∗ 2 − 14 + 0 ∗ 2 − 15 + 0 ∗ 2 − 16 + 1 ∗ 2 − 17 + 1 ∗ 2 − 18 + 0 ∗ 2 − 19 + 0 ∗ 2 − 20 + 1 ∗ 2 − 21 + 1 ∗ 2 − 22 + 0 ∗ 2 − 23 0*2^{1} + 1*2^{-2}+ 0*2^{-3}+ 0*2^{-4}+ 1*2^{-5}+ 1*2^{-6}+ 0*2^{-7}+ 0*2^{-8}+ 1*2^{-9}+ 1*2^{-10}+ 0*2^{-11}+ 0*2^{-12}+ 1*2^{-13}+ 1*2^{-14}+ 0*2^{-15}+ 0*2^{-16}+ 1*2^{-17}+ 1*2^{-18}+ 0*2^{-19}+ 0*2^{-20}+ 1*2^{-21}+ 1*2^{-22}+ 0*2^{-23} 021+122+023+024+125+126+027+028+129+1210+0211+0212+1213+1214+0215+0216+1217+1218+0219+0220+1221+1222+0223
= 0 + 0.25 + 0 + 0 + 0.03125 + 0.015625 + 0 + 0 + 0.001953125 + 0.0009765625 + 0 + 0 + 0.0001220703125 + 0.00006103515625 + 0 + 0 + 0.00000762939453125 + 0.000003814697265625 + 0 + 0 + 0.000000476837158203 + 0.000000238418579101 + 0 0+ 0.25+ 0+ 0+ 0.03125+ 0.015625+ 0+0+ 0.001953125+ 0.0009765625+ 0+ 0+ 0.0001220703125+ 0.00006103515625+0+ 0+ 0.00000762939453125+ 0.000003814697265625+ 0+ 0+ 0.000000476837158203+ 0.000000238418579101+ 0 0+0.25+0+0+0.03125+0.015625+0+0+0.001953125+0.0009765625+0+0+0.0001220703125+0.00006103515625+0+0+0.00000762939453125+0.000003814697265625+0+0+0.000000476837158203+0.000000238418579101+0
= 0.299999952316284179


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

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

相关文章

竞赛选题 深度学习+opencv+python实现车道线检测 - 自动驾驶

文章目录 0 前言1 课题背景2 实现效果3 卷积神经网络3.1卷积层3.2 池化层3.3 激活函数:3.4 全连接层3.5 使用tensorflow中keras模块实现卷积神经网络 4 YOLOV56 数据集处理7 模型训练8 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 &am…

在服务器上解压.7z文件

1. 更新apt sudo apt-get update2. 安装p7zip sudo apt-get install p7zip-full3. 解压.7z文件 7za x WN18RR.7z

java合成多个pdf为一个pdf

pom文件 <dependency><groupId>com.lowagie</groupId><artifactId>itext</artifactId><version>2.1.7</version></dependency>主文件 import com.lowagie.text.Document; import com.lowagie.text.pdf.PdfCopy; import com.lo…

求三维坐标绕坐标轴旋转后的坐标值

目的 旋转矩阵 应用 沿单个坐标轴旋转 沿多个坐标系旋转 目的 由于其他文章原理介绍比较详细&#xff0c;但应用方面较少。本文直接介绍旋转矩阵的应用&#xff0c;条件为坐标系不变&#xff0c;求旋转后的三维坐标。本文方法较傻瓜式&#xff0c;需要自己进行测试以确认是…

HUAWEI(26)——防火墙双机热备

一、拓扑 二、需求 PC2 ping PC1 FW1与FW2双机热备,FW1为active,FW2为Standby,抢占延时1s VRRP 三、配置 1.IP地址,防火墙接口加入区域 防火墙用户名:admin 防火墙旧密码:Admin@123 防火墙新密码:admin@123 [FW1]interface GigabitEthernet 1/0/0 [FW1-GigabitEthe…

振弦传感器和无线振弦采集仪在隧道安全监测的解决方案

振弦传感器和无线振弦采集仪在隧道安全监测的解决方案 隧道作为交通工程的重要组成部分&#xff0c;具有极高的安全风险&#xff0c;因此隧道安全监测是必不可少的。振弦传感器和无线振弦采集仪作为隧道安全监测的两种重要设备&#xff0c;能够有效地监测隧道的振动情况&#…

elasticsearch(ES)分布式搜索引擎03——(RestClient查询文档,ES旅游案例实战)

目录 3.RestClient查询文档3.1.快速入门3.1.1.发起查询请求3.1.2.解析响应3.1.3.完整代码3.1.4.小结 3.2.match查询3.3.精确查询3.4.布尔查询3.5.排序、分页3.6.高亮3.6.1.高亮请求构建3.6.2.高亮结果解析 4.旅游案例4.1.酒店搜索和分页4.1.1.需求分析4.1.2.定义实体类4.1.3.定…

解决uniapp里scroll-view横向滚动的问题

一、前言 本以为是一件很简单的事&#xff0c;结果浪费了整整一个上午&#xff0c;并且问题并没有全部解决....后来没办法&#xff0c;用了touchmove模拟的滑动&#xff0c;如果有好的解决方法麻烦告诉我...非常感谢~ 一、问题 其实我想要实现的功能很简单&#xff0c;就是一…

微服务、SOA 和 API 之间的区别

在软件开发中&#xff0c;组织的投资方式发生了重大转变&#xff0c;部署了面向架构的方法。这一切都始于 SOA&#xff0c;然后转变为我们称之为微服务的东西。添加到其中的是另一个概念&#xff0c;指定为 API。 在过去的几年里&#xff0c;SOA 和微服务仍然是讨论的话题。随…

【红外双目有监督】CATS系列数据集探索加载器

论文&#xff1a; CATS: A Color and Thermal Stereo Benchmark https://www. flir.com/oem/adas/adas-dataset-form/.Flir thermal dataset 数据集规格 内容 总共 26,442 个 完全注释的帧&#xff0c;以及 15 个不同对象类别的520,000 个 边界框注释。 图片 9,711 张热图像和…

Lazysysadmin靶机

信息收集 主机发现 nmap -sn 192.168.88.0/24 //-sn&#xff1a;制作主机发现&#xff0c;不做端口扫描&#xff1b;扫描结果包含本机IP 端口扫描 nmap --min-rate 10000 -p- 192.168.88.136 扫描端口详细信息 端口扫描发现&#xff0c;该主机的22、80、139、445、3306、…

软件开源快速开发框架:降本增效,助力流程化办公!

随着时代的进步和社会的发展&#xff0c;应用软件开源快速开发框架的优势特点&#xff0c;可以让不少客户朋友顺利实现流程化办公&#xff0c;朝着数字化方向迈进。流辰信息是专业研发低代码技术平台的服务商&#xff0c;一直在低代码平台领域深耕细作&#xff0c;努力钻研&…

合并两个有序数组

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2&#xff0c;另有两个整数 m 和 n &#xff0c;分别表示 nums1 和 nums2 中的元素数目。 请你 合并 nums2 到 nums1 中&#xff0c;使合并后的数组同样按 非递减顺序 排列。 注意&#xff1a;最终&#xff0c;合并后数组…

【spring data jpa】数据的增删改查(CRUD)

一、添加依赖 在pom文件中添加spring data jpa依赖 <dependency><groupId>org.springframework.data</groupId><artifactId>spring-data-jpa</artifactId><version>3.1.4</version> </dependency> <dependency><gr…

如何使用 arrayList.removeAll(Collection<?> c)?

引言 对于 Collection 集合及其实现类都有 removeAll(Collection<?> c)。 对于ArrayList 的实例对象&#xff0c;在数据比较多的情况下&#xff0c;方法 removeAll() 的传参 c 的类型是 HashSet会比是 ArrayList 的情况快的多。 原因 我们来细看一下ArrayList类的re…

perf性能分析

安装 apt install linux-tools-common linux-tools-generic 可能安装在/usr/bin/perf&#xff0c;如果版本不对&#xff0c;可以看看 /usr/lib/linux-tools/[version]/ 下有没有perf&#xff0c;如果有的话替换一下就可以 使用 perf record -g -p pid # 记录数据&#x…

C++桶排序算法的应用:存在重复元素 III

题目 给你一个整数数组 nums 和两个整数 indexDiff 和 valueDiff 。 找出满足下述条件的下标对 (i, j)&#xff1a; i ! j, abs(i - j) < indexDiff abs(nums[i] - nums[j]) < valueDiff 如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例…

城市广告牌安全传感器特点有哪些?

城市广告牌安全传感器特点有哪些&#xff1f; 在现代快节奏的都市生活中&#xff0c;城市的广告牌成为不可或缺的一部分&#xff0c;以各种形式和大小存在于城市的街头巷尾&#xff0c;商业中心和交通要道。广告牌是城市生命线组成的一部分。但是由于天气因素、材料老化、不当维…

MySQL [基础]] 学习笔记

MySQL 学习 文章目录 MySQL 学习1. 数据库三层结构2. 数据在数据库中的存储方式3. SQL 语句分类3.1 备份恢复数据库的表 4. Mysql 常用数据类型(列类型)4.1 数值型(整数)的基本使用4.2 数值型(bit)的使用4.3 数值型(小数)的基本使用4.4 字符串的基本使用(面试题)4.5 字符串使用…

【JUC】JMM

文章目录 1. 概述2. 三大特性2.1 可见性2.2 原子性2.3 有序性 3. 多线程对变量的读写过程4. 先行发生原则(happens-before) 1. 概述 CPU的运行并不是直接操作内存而是先把内存里边的数据读到缓存&#xff0c;而内存的读和写操作的时候就会造成不一致的问题 JVM规范中试图定义…