关于数制及其转换杂谈

2023-10-30 02:59
文章标签 转换 杂谈 数制

本文主要是介绍关于数制及其转换杂谈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于数制及其转换杂谈

从1除以10谈起

十进制计算

1 ÷ 10 = 0.1

商是有限小数

用二进制计算 是无限循环小数:

1 ÷ 1010 = 0.00011001100110011……

1/10 是无法用二进制小数精确表示的。十进制小数转换成二进制有可能无限循环。

十进制数0.1转换成二进制为0.000110001100011……

十进制小数转换成二进制

以小数点为界,拆分整数部分和纯小数部分转换

整数部分转换二进制,使用的是“除2取余法”。

小数部分的转换不同于整数部分,使用的是“乘2取整法”

例如:

整数部分除二取余法,直到商为0为止;小数部分不断乘以2,每次得到的整数部分就是二进制数的每一位,直到小数部分为0或达到需要的精度为止。箭头代表书写顺序。

二进制转换成十进制

以小数点为界,拆分整数部分和纯小数部分转换。对于整数部分,从左到右依次乘以2的幂,并将结果相加;对于小数部分,从右到左依次乘以2的负幂,并将结果相加。参加下图:

 

 python实现十进制小数转换成二进制的源码

 下面给出python实现十进制小数转换成二进制的源码:

#十进制浮点数转二进制函数
def dectbin(num):# 判断是否为浮点数if num == int(num):# 若为整数integer = '{:b}'.format(int(num))return integerelse:# 若为浮点数# 取整数部分integer_part = int(num)# 取小数部分decimal_part = num - integer_part# 整数部分进制转换integercom = '{:b}'.format(integer_part)  #{:b}.foemat中b是二进制# 小数部分进制转换tem = decimal_parttmpflo = []# for i in range(accuracy):A = Truewhile A:tem *= 2tmpflo += str(int(tem))  #若整数部分为0则二进制部分为0,若整数部分为1则二进制部分为1 #将1或0放入列表if tem > 1 :   #若乘以2后为大于1的小数,则要减去整数部分tem -= int(tem)elif tem < 1:  #乘以2后若仍为小于1的小数,则继续使用这个数乘2变换进制passelse:    #当乘以2后正好为1,则进制变换停止breakflocom = tmpfloreturn integercom + '.' + ''.join(flocom)number = float(input("输入一个正的浮点数:"))
result = dectbin(number)
print(f'{number}的二进制数为:{result}')

为什么大多数的十进制小数都不能精确地表示为二进制小数?

浮点算术:争议和限制 https://docs.python.org/zh-cn/3/tutorial/floatingpoint.html

浮点数在计算机硬件中以2进制(二进制)分数表示。例如,十进制分数0.125的值为1/10+2/100+5/1000,二进制分数0.001的值为0/2+0/4+1/8。这两个分数具有相同的值,唯一真正的区别是第一个分数以10为基数的分数表示法书写,第二个分数以2为基数。

不幸的是,大多数的十进制小数都不能精确地表示为二进制小数。这导致在大多数情况下,你输入的十进制浮点数都只能近似地以二进制浮点数形式储存在计算机中。

表示性错误 是指某些(其实是大多数)十进制小数无法以二进制(以 2 为基数的计数制)精确表示这一事实造成的错误。 这就是为什么 Python(或者 Perl、C、C++、Java、Fortran 以及许多其他语言)经常不会显示你所期待的精确十进制数值的主要原因。

因此,程序员需要注意,浮点数交给计算机存储的时候,可能会有精度丢失问题!

浮点数在计算机中是如何表示的?

只要给出:符号(S)、阶码部分(E)、尾数部分(M) 这三个维度的信息,一个浮点数的表示就完全确定下来了,所以float和double这两种类型的浮点数在计算机中的存储结构就表示成下图所示这个样子:

1、符号部分(S)

0:正;1:负

2、阶码部分(E)(指数部分):

对于float型浮点数,指数部分8位,考虑可正可负,因此可以表示的指数范围为-127 ~ 128;

对于double型浮点数,指数部分11位,考虑可正可负,因此可以表示的指数范围为-1023 ~ 1024。

3、尾数部分(M):

浮点数的精度是由尾数的位数来决定的:

对于float型浮点数,尾数部分23位,换算成十进制就是 2^23=8388608,所以十进制精度只有6 ~ 7位;

对于double型浮点数,尾数部分52位,换算成十进制就是 2^52 = 4503599627370496,所以十进制精度只有15 ~ 16位。

在线(支持浮点型)进制转换https://tool.oschina.net/hexconvert/

在线二进制计算器https://miniwebtool.com/zh-cn/binary-calculator/ 

十进制的无理数是否在某一进制下是有理数?https://www.zhihu.com/question/329019394 


 


 

这篇关于关于数制及其转换杂谈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305154

相关文章

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

Java如何将文件内容转换为MD5哈希值

《Java如何将文件内容转换为MD5哈希值》:本文主要介绍Java如何将文件内容转换为MD5哈希值的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java文件内容转换为MD5哈希值一个完整的Java示例代码代码解释注意事项总结Java文件内容转换为MD5

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Java实现视频格式转换的完整指南

《Java实现视频格式转换的完整指南》在Java中实现视频格式的转换,通常需要借助第三方工具或库,因为视频的编解码操作复杂且性能需求较高,以下是实现视频格式转换的常用方法和步骤,需要的朋友可以参考下... 目录核心思路方法一:通过调用 FFmpeg 命令步骤示例代码说明优点方法二:使用 Jaffree(FF

C语言中的常见进制转换详解(从二进制到十六进制)

《C语言中的常见进制转换详解(从二进制到十六进制)》进制转换是计算机编程中的一个常见任务,特别是在处理低级别的数据操作时,C语言作为一门底层编程语言,在进制转换方面提供了灵活的操作方式,今天,我们将深... 目录1、进制基础2、C语言中的进制转换2.1 从十进制转换为其他进制十进制转二进制十进制转八进制十进

Pandas进行周期与时间戳转换的方法

《Pandas进行周期与时间戳转换的方法》本教程将深入讲解如何在pandas中使用to_period()和to_timestamp()方法,完成时间戳与周期之间的转换,并结合实际应用场景展示这些方法的... 目录to_period() 时间戳转周期基本操作应用示例to_timestamp() 周期转时间戳基