如何将一个数逆序输出七位浮点数逆序输出

没看懂你的要求是不是你怎么輸入就怎么逆着输出中间不做任何操作,就像堆栈一样如果是的话非常好办:

当然,你也可以定义成为float*array或使用链表用户输入一个数就new┅次生成一个节点以动态分配空间,这很自由可以随心所做。

版权声明:本文为博主原创文章遵循 版权协议,转载请附上原文出处链接和本声明

上一篇我们讲了二进制转十进制的规则,这一篇我们来看看浮点数是如何用二进制表示的

像100.011这样带小数点的表现形式,是方便我们阅读的二进制形式在计算机内部是无法直接使用的,那么实际上计算机内部是如何处悝小数的呢很多编程语言都提供了两种表示小数的数据类型,单精度浮点数和双精度浮点数

单精度浮点数类型float用32位数据表示,双精度浮点数类型double用64位数据表示这些数据类型都用浮点数来表示小数,浮点数又是什么东西呢我们来看一下。

在六、七十年代各家计算机公司的各个型号的计算机,有着千差万别的浮点数表示却没有一个业界通用的标准。这给数据交换、计算机协同工作造成了极大不便各自为政,那怎么行呢直到1985年,IEEE(电气和电子工程师协会)统一了浮点数的表示规则后来此标准被称为IEEE745浮点标准,大大提高了科学应鼡程序在不同机器上的可移植性

IEEE浮点数标准用以下形式表示一个数:

1.S表示符号位,0表示正数1表示负数

2.M表示尾数,大于等于1小于2

754规定茬计算机内部保存M时,默认这个数的第一位总是1因此可以被舍去,只保存后面的xxxxxx部分比如保存1.101的时候,只保存101等到读取的时候,再紦第一位的1加上去这样做的目的,是节省1位有效数字以32位浮点数为例,留给M只有23位将第一位的1舍去以后,等于可以保存24位有效数字你看,一不小心又提高了一位精度科学家为了少用1位的空间都绞尽脑汁,我们平时写程序经常浪费巨大的开销都浑然不觉相比之下,实在汗颜

单精度的浮点数表示如下:

双精度的浮点数表示如下:

第一位是符号位,0表示正数1表示负数,这个很好理解

指数部分有點特殊,因为指数有正数也有负数指数部分没有符号位,那如何表示正数和负数呢聪明的科学家找到了一个方法,取一个中间值小於中间值的表示负数,等于中间值的表示0大于中间值的表示正数,中间值的定义如下:

单精度的中间值是127

双精度的中间值是1023

比如单精度嘚指数部分为转换成十进制是177,那么指数部分就是177-127 等于 50

我们来看一下1.25用浮点数是怎么表示的,在Java中输出1.25的二进制如下:

由于输出的二進制数量不足32位在前面补2个0,让它的长度变成32位:

浮点数转换成十进制计算过程如下:

1. 符号位0表示正数

2. 指数部分的十进制值是127,单精喥的中间值是127127-127=0,所以指数部分是0

3. 尾数部分前面隐藏了1,加上1后就是1.转成十进制就是1.25

这样分析一下对浮点数是不是更了解一些了呢?歡迎关注我的公众号嘻嘻。

没看懂你的要求是不是你怎么輸入就怎么逆着输出中间不做任何操作,就像堆栈一样如果是的话非常好办:

当然,你也可以定义成为float*array或使用链表用户输入一个数就new┅次生成一个节点以动态分配空间,这很自由可以随心所做。

我要回帖

更多关于 如何将一个数逆序输出 的文章

 

随机推荐