二进制、十进制转换进阶--小数点后的转换

上一篇文章详细介绍了整数的二进制,八进制,十进制,十六进制之间的转换

详情可前往:二进制、八进制、十进制、十六进制的相互转换-CSDN博客

这篇介绍含有小数点之间的转换

一:二进制转十进制

二进制 101.11 可以分为两部分 101 和 0.11

整数部分 101 转换的方式是从右到左,每个数乘以2的N次方(N从0开始),再相加

小数部分0.11 则是从左往右,每个数除以2的M次方(N从1开始),再相加

整数部分:

小数部分:

整数部分和小数部分拼接起来就是5.75

所以二进制101.11转为十进制的结果为 5.75

二:十进制转二进制

十进制5.625转换二进制,依旧分为整数部分和小数部分来转.

整数部分5除以2,直到商为0,取余数倒叙排列

小数部分0.625乘以2,每次取积的整数部分,小数部分继续乘以2,直到小数部分为0,最后取整数部分的正序排列

最后把整数部分拼接上小数部分,即得到转换后的答案

整数部分:

5 除以 2, 得到2 ---> 取余数 1

2 除以 2, 得到 1---> 取余数 0

1 除以 2, 得到 0 ---> 取余数 1 (商位0,停止操作)

则5的二进制位 101 (注:这里巧合101 的正序和倒叙一样,但是你要明白,是从第三步->第二步->第一步 取的)

小数部分:

0.625 乘以 2得到 1.25 ---> 取整数 1

0.25 乘以 2 得到 0.5 ---> 取整数 0

0.5 乘以 2 得到 1.0 ---> 取整数 1 (小数位0,停止操作)

则0.625的二进制位 101 (注:这里巧合101 的正序和倒叙一样,但是你要明白,是从第一步->第二步->第三步 取的)

整数部分和小数部分拼接起来就是101.101

所以十进制5.625转为二进制的结果为 101.101

相关推荐
wuweijianlove6 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung6 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了6 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL6 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰6 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商7 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug9997 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
CN-Dust9 小时前
【C++】while语句例题专题
数据结构·c++·算法
灵智实验室9 小时前
PX4位置速度估计技术详解(四):LPE 激光雷达高度融合的实现错误
算法·无人机·px 4
CQU_JIAKE9 小时前
【A】3742,3387,并查集
算法