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

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

详情可前往:二进制、八进制、十进制、十六进制的相互转换-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

相关推荐
Codeking__11 分钟前
”一维前缀和“算法原理及模板
数据结构·算法
休息一下接着来12 分钟前
C++ 条件变量与线程通知机制:std::condition_variable
开发语言·c++·算法
Code哈哈笑25 分钟前
【机器学习】支持向量回归(SVR)从入门到实战:原理、实现与优化指南
人工智能·算法·机器学习·回归·svm
努力学习的小廉36 分钟前
【C++】 —— 笔试刷题day_29
开发语言·c++·算法
小羊在奋斗37 分钟前
【LeetCode 热题 100】搜索插入位置 / 搜索旋转排序数组 / 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
meisongqing43 分钟前
【软件工程】符号执行与约束求解缺陷检测方法
人工智能·算法·软件工程·软件缺陷
莫叫石榴姐1 小时前
如何为大模型编写优雅且高效的提示词?
人工智能·算法
Echo``2 小时前
1:OpenCV—图像基础
c++·图像处理·人工智能·opencv·算法·计算机视觉·视觉检测
COOCC13 小时前
激活函数全解析:定义、分类与 17 种常用函数详解
人工智能·深度学习·神经网络·算法·机器学习·计算机视觉·自然语言处理
林下清风~3 小时前
力扣hot100——347.前K个高频元素(cpp手撕堆)
算法·leetcode·职场和发展