用贪心算法计算十进制数转二进制数(小数部分)

在上一篇博文用贪心算法计算十进制数转二进制数(整数部分)-CSDN博客中,小编介绍了用贪心算法进行十进制整数转化为二进制数的操作步骤,那么有朋友问我,那十进制小数转二进制,可以用贪心算法来计算吗?我研究了一下,发现也是可以用的,下边介绍一下操作步骤。

目录

一、乘2正向取整法

二、十进制小数转化为二进制小数的数学原理

三、贪心算法

1、贪心算法简介

2、操作步骤

3、结论


一、乘2正向取整法

在介绍贪心算法之前,还是先介绍一下常用的计算方法,就是“乘2取整”法。

这种方法就是把十进制的小数部分乘2,并记录得到的积的整数部分,把积的整数部分减掉,再把积的小数部分进行乘2,并记录得到的积的整数部分,依次乘2取整,直到乘2后得到的积为1,也就是整数部分为1,小数部分为0时,转化完成。转化完成后,从上往下(正向)依次把整数部分排列起来,就是转化后的二进制小数。

图1 乘2取整法

注意,并不是所有的十进制小数都能精确地转化为二进制小数。如果出现乘2后的积一直不为1的情况时,此十进制小数就不能精确转化为二进制小数,只能无限接近。

例如,十进制小数0.15就无法精确地转换为二进制,转化的结果为0.001001100110011……循环不尽,无法得到精确转化值。

二、十进制小数转化为二进制小数的数学原理

通过观察图1,可以看出:

0.6875=1\times 2^{-1}+0\times 2^{-2}+1\times 2^{-3}+1\times 2^{-4}                                       (1)

一般的表达式为:

   a=\sum_{i=1}^{i=n}\left ( c_{i}\ast 2^{-i} \right ),c_{i}\in \left \{ 0,1 \right \}                                                              (2)

十进制小数转化为二进制小数的过程就是把系数c_{i}i=1i=n(从最高位到最低位)的排列。   

在(1)式中,c_{1}=1,c_{2}=0,c_{3}=1,c_{4}=1,所以\left ( 0.6875 \right )_{10}=\left ( 0.1011 \right )_{2}

如果把(1)式中的系数 c_{_i}=0 的项去掉,那么有

0.6875=1\times 2^{-1}+1\times 2^{-3}+1\times 2^{-4}                                           (3)

也就是把十进制小数转换为二进制小数的过程,实际上就是把十进制小数转换为若干个以2为底的幂运算之和,那么一般表达式为:

a=\sum_{i=0}^{i=m}2^{-n_{i}}                                                                       (4)

在(3)式中,n_{0}=1,n_{1}=3,n_{2}=4。也就是在十进制小数0.6825转换为二进制小数后,数位序号为1,3,4的项系数为1,其他项系数都为0(数位序号从左向右依次增1,最低位序号为1),如表1所示,表格中橙色项系数为1,白色项系数为0。

表1 十进制小数0.6875的二进制转换结果
位序号1234
位权重1/21/41/81/16
项系数1011
二进制数1011

三、贪心算法

那么如何快速计算出(4)式的n_{i}呢?与十进制整数转化二进制数类似,也可以用贪心算法进行计算。

1、贪心算法简介

贪心算法(又称贪婪算法)是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,他所做出的是在某种意义上的局部最优解。

2、操作步骤

假设十进制数为a,根据公式(4),用贪心算法思维进行十进制小数转二进制小数计算的步骤为:

(1)先找出a中最大的那一项2^{-n_{i}},并记录n_{i}

(2)把最大项的值从​​​​​​​a中减掉:a=a-2^{-n_{i}}

(3)跳转到步骤(1)循环计算,直到​​​​​​​a=0a\leqslant给定极小值,计算结束。

为了人工计算更直观,我们通常把2^{-n_{i}}写为小数形式0.5,0.25,0.125,0.0625,0.03125

因此(1)式右边的指数形式转化为小数形式

0.6825=1\times 0.5+0\times 0.25+1\times0.125+1\times 0.0625                              (5)

同样,可以把(3)式改写为:

0.6825=1\times 0.5+1\times0.125+1\times 0.0625                                        (6)

下边以十进制小数a=0.6875转化为二进制小数为例,介绍贪心算法的计算步骤:

(1)找出0.6875中最大的项为0.5,也就是2^{-1},记录n_{0}=1

(2)a=0.6875-0.5=0.1875

(3)找出0.1875中最大的项为0.125,也就是2^{-3},记录n_{1}=3

(4)a=0.1875-0.125=0.0625

(5)找出0.0625中最大的项为0.0625,也就是2^{-4},记录n_{1}=4

(6)a=0.0625-0.0625=0,计算结束;

计算的结果为:0.6875=0.5+0.125+0.0625=2^{-1}+2^{-3}+2^{-4}

二进制小数位序号为1,3,4的项为1,其他位序号的项为0,计算结果为\left ( 0.6875 \right )_{10}=\left ( 0.1011 \right )_{2}

3、结论

对比乘2取整法和贪心法,可以发现,对于可以转化为精确二进制小数的情况来说,贪心算法计算量少,准确率较高,不容易算错,也更直观,更好理解和记忆,但是需要我们事先记住一些常用的2^{-n}的值,这样才有助于我们更快找出最大项。表2为1\leqslant n\leqslant 52^{-n}的值。

表2 常用2为底幂的值

2^{-n}2^{-1}2^{-2}2^{-3}2^{-4}2^{-5}
0.50.250.1250.06250.03125

(本文结束)

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

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

相关文章

错误模块路径: ...\v4.0.30319\clr.dll,v4.0.30319 .NET 运行时中出现内部错误,进程终止,退出代码为 80131506。

全网唯一解决此BUG的文章!!! 你是否碰到了以下几种问题?先说原因解决思路具体操作1、首先将你C:\Windows\Microsoft.NET\文件夹的所有者修改为你当前用户,我的是administrator。2、修改当前用户权限。3、重启电脑4、删…

童心绘梦,味在蒙自源 —— 蒙自源六一儿童节特别活动

当六月的阳光洒满大地,阵阵知了的叫声唤醒了沉睡的花朵,也唤醒了所有人心中的那份纯真与梦想。每个孩子都是天生的梦想家。他们用纯真的双眼观察世界,用无畏的心灵探索未知。今年的六一儿童节,不仅是孩子们的节日,也是…

数学建模 —— 插值与拟合(1)

一、matlab画图 1.1 plot(二维图形) plot(x) —— 缺省自变量绘图格式 plot(x,y) —— 基本格式,以y(x)的函数关系作出直角坐标图,如果y为nm的矩阵,则以x为自变量,作出m条曲线 plot(x1,y1,x2,y2,…,xn,…

【MySQL数据库】索引与事务

🔥个人主页: 中草药 🔥专栏:【MySQL】探秘:数据库世界的瑞士军刀 目录 🗳️一.索引 📮1.工作原理 📬2.类型 📭3.作用 📪4.优缺点 📫5.使用…

Git远程操作

下面演示在gitee上创建远程仓库 创建远程仓库 上面的.gitignore是为了在上传时过滤掉不重要的文件,分支模型选单分支模型就够用了,或者选生产/开发模型。 当然,如果创建仓库的时候没有添加.gitignore文件,可以在本地仓库创建.gi…

Nvidia Jetson/Orin +FPGA+AI大算力边缘计算盒子:美团小袋自动配送车

大型电商公司美团已选用NVIDIA Jetson AGX Xavier 平台,作为无人配送机器人核心AI算力。 美团点评是全球大型的按需食品配送公司,结合了Uber Eats、Yelp和Groupon的商业模式,与超过40万家本地企业开展合作。他们推出了小袋自动配送车&#…

【OpenHarmony】TypeScript 语法 ③ ( 条件语句 | if else 语句 | switch case 语句 )

文章目录 一、条件语句1、if else 语句2、switch case 语句 参考文档 : <HarmonyOS第一课>ArkTS开发语言介绍 一、条件语句 1、if else 语句 TypeScript 中的 if 语句 / if else 语句 用法 , 与 JavaScript 语言中的 if 语句 / if else 语句 语法 基本相同 ; if else 语…

QT 信号和槽教程,窗体和控件对象之间的沟通一般都使用信号和槽

Qt的信号和槽&#xff08;Signals and Slots&#xff09;机制是一种强大的对象间通信方式&#xff0c;它允许对象在完全解耦的情况下相互通信。以下是关于Qt信号和槽的简明教程&#xff1a; 基本概念 信号&#xff08;Signal&#xff09;&#xff1a;信号是由Qt对象发出的通知…

Docker 快速更改容器的重启策略(Restart Policies)以及重启策略详解

目录 1. 使用 docker update 命令2. 在启动容器时指定重启策略3. 在 Docker Compose 文件中指定重启策略4. 总结 官方文档&#xff1a;Start containers automatically 1. 使用 docker update 命令 Docker 提供了 docker update 命令&#xff0c;可以在容器运行时更改其重启策…

Elasticsearch:基于多个 kNN 字段对文档进行评分

作者&#xff1a;来自 Elastic Madhusudhan Konda 通过具有多个 kNN 字段的最接近的文档对文档进行评分 Elasticsearch 不仅仅是一个词法&#xff08;文本&#xff09;搜索引擎。 Elasticsearch 是多功能搜索引擎&#xff0c;除了传统的文本匹配之外&#xff0c;还支持 k 最近…

华为设备配置静态路由和默认路由

华为设备配置静态路由和默认路由 理论部分知识&#xff1a; 路由分为两个大类&#xff1a;静态路由-----动态路由 静态路由&#xff1a;手工指定&#xff0c;适用于小规模的网络应用场景&#xff0c;如果网络规模变大&#xff0c;这样的方式非常不适合而且容易出错。 语法&…

【JavaEE进阶】——Mybatis操作数据库(使用注解和XML方式)

目录 &#x1f6a9;三层架构 &#x1f388;JDBC操作回顾 &#x1f6a9;什么是MyBatis &#x1f6a9;MyBatis⼊⻔ &#x1f388;准备工作 &#x1f4dd;创建⼯程 &#x1f4dd;数据准备 &#x1f388;配置数据库连接字符串 &#x1f388;写持久层代码 &#x1f388;单…

STM32作业设计

目录 STM32作业设计 STM32作业实现(一)串口通信 STM32作业实现(二)串口控制led STM32作业实现(三)串口控制有源蜂鸣器 STM32作业实现(四)光敏传感器 STM32作业实现(五)温湿度传感器dht11 STM32作业实现(六)闪存保存数据 STM32作业实现(七)OLED显示数据 STM32作业实现(八)触摸按…

PyQt5创建与MySQL数据库集成的应用程序

最近&#xff0c;对之前的mysql管理系统进行了更新升级&#xff0c;制作了一版关于车牌的管理系统&#xff01; &#xff08;1&#xff09;实现了对车牌和用户基本信息的增删改查的功能 &#xff01; &#xff08;2&#xff09;加入了对数据库的刷新和状态显示功能 &#xff…

没有知网资源如何快速下载知网论文

今天有位同学求助一篇知网论文&#xff0c;“球磨-点击化学反应&#xff1a;无溶剂绿色反应方式”&#xff0c;其实下载知网论文是一件非常简单的事情&#xff0c;下面小编就把如何在家轻松查找下载知网论文的方法给大家演示一遍。 一、首先你需要获取知网使用权限&#xff0c…

css特殊效果和页面布局

特殊效果 圆角边框&#xff1a;div{border-radius: 20px 10px 50px 30px;} 四个属性值按顺时针排列&#xff0c;左上的1/4圆半径为20px&#xff0c;右上10&#xff0c;右下50&#xff0c;左下30。 div{border-radius: 20px;} 四角都为20px。 div{border-radius: 20px 10…

Maven配置

Maven – Download Apache Maven https://maven.apache.org/install.html 得下载有 bin的

MongoDB~俩大特点管道聚合和数据压缩(snappy)

场景 在MySQL中&#xff0c;通常会涉及多个表的一些操作&#xff0c;MongoDB也类似&#xff0c;有时需要将多个文档甚至是多个集合汇总到一起计算分析&#xff08;比如求和、取最大值&#xff09;并返回计算后的结果&#xff0c;这个过程被称为 聚合操作 。 根据官方文档介绍&…

Facebook开户 | Facebook二不限户

Facebook二不限户的正确使用方法 Facebook 二不限是指 Facebook 国内二不限户&#xff0c;是通过代理开出来的一种特殊账户&#xff0c;️需要广告主准备主页。 其特点是&#xff1a;限主页、不限域名、额度没解限&#xff0c;解限后则不限额度。 相比于三不限户&#xff0c;…

Notepad++不显示CRLF的方法

View -> Show Symbol -> 去掉勾选 Show All Characters