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

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

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

相关推荐
Dlrb12113 小时前
C语言-指针三
c语言·算法·指针·const·命令行参数
Tisfy3 小时前
LeetCode 2540.最小公共值:双指针(O(m+n))
算法·leetcode·题解·双指针
IronMurphy3 小时前
【算法四十七】152. 乘积最大子数组
算法
淘矿人4 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
Cosolar4 小时前
万字详解:RAG 向量索引算法与向量数据库架构及实战
数据库·人工智能·算法·数据库架构·milvus
落羽的落羽6 小时前
【算法札记】练习 | Week4
linux·服务器·数据结构·c++·人工智能·算法·动态规划
萑澈7 小时前
算法竞赛入门:C++ STL核心用法与时空复杂度速查手册
数据结构·c++·算法·stl
Godspeed Zhao7 小时前
从零开始学AI16——SVM
算法·机器学习·支持向量机
江屿风7 小时前
C++OJ题经验总结(竞赛)1
开发语言·c++·笔记·算法