有问题就有答案
Q1:求计算机编码高手指教:
应该是 B语言或者VB语言,
Q2:实数真值-2.5如果用单精度规格化浮点数据格式表达,其编码是什么?要求给出转换过程
c、这样定义的单精度数据的——有32个二进制位、1个符号位、8位代码(要移动的小数点个数)和23个尾数位:最高有效位是符号位,1表示负数,0表示正数。这里-2.5,所以取1。然后是8位顺序码,由移位码表示,最高位为符号,0为负,1为正。单精度应该比原值高127,即加0111111。后面写尾数原码,无限小数写23位。注意原代码要改为以1开头(即小数点移到第一个有效的1后,恢复时小数点按顺序码指示向哪个方向移动),小数点前写1。对于-2.5,转换如下:尾数:原来2.5的二进制码是10.1,变成1.01,小数点前省略1变成01,就是尾数。顺序码:小数点从1.01恢复到10.1时要向右移位一位,所以顺序码符号为1(正),移位值为000001;0000001 1111111=10000000。这是-2.5的订单代码。完整代码:1 1000000001-110000000010000000000000000000000003354,因为小数点后的0没有数学意义,但是32位数字应该用c来填充,最后,数字1100000000000010000000000000000000000000000000000000000000000000000000000000000000000000000000000000我想知道这是不是你要问的。
Q3:如何求出计算机中单精度浮点数的表数范围?(具体过程)
别问了,网上有一些:单精度数的尾数存储在23位,加上小数点前的默认数字1,2(23 ^ 1)=16777216。因为10 7 16777216 10 8,单精度浮点数的有效位数是7位。双精度的尾数以52位存储,2 (52 1)=9007199254740992。因为10 16 9007199254740992 10 17,双精度的有效位数是16位。扩展数据:“浮点数的精度取决于尾数。尾数部分的位数越多,可以表示的有效位数就越多。”我同意这句话,所以双精度的有效位数一定比单精度的多。如果一个数字的有效位数超过7位,如1.27893456076(12位),用浮点数表示时就不能准确存储。Run :float a=1.23456789076f//-A=1.2345679,即1.23456789076,以浮点格式存储在计算机中,只能逼近第七位数字,能否准确存储取决于这个数字(十进制数)能否用有限的二进制数字准确表示。Float=2.202 float=2.25如果在将小数部分转换为二进制时得到一个无穷大的值,那么冗余部分将根据尾数部门的长度被丢弃,从而存储一个近似的浮点值,这就解释了为什么在比较浮点值时应该进行区间比较而不是等价比较。溢出处理浮点数的溢出由其顺序代码的溢出来表示。检查加减运算时是否发生溢出:如果顺序码正常,则加(减)运算正常结束;如果订单代码溢出,应该进行相应的处理。此外,尾数溢出也需要处理。代码溢出超过了代码可能表示的最大值的正指数值,通常认为该值为和-。代码下溢超过了代码可能表示的最小值的负指数值,该值通常被认为是0。尾数溢出。两个相同的带符号尾数相加产生最高位向上的进位。尾数向右移动,顺序码增加1重新排列。尾数下溢当您将尾数向右移动时,尾数的最低有效位从尾数字段的右端流出,需要四舍五入。参考:百度百科——浮点数。
Q4:c语言中的单精度数据的有效位数是什么意思?
c语言中的单精度数据的有效位数是7位。c语言中的单精度浮点数的实际有效精度为24位二进制,这相当于 24*log102≈7.2 位10进制的精度。尾数用23位存储,加上默认的小数点前的1位1,2^(23+1) = 16777216。因为 10^7 < 16777216 < 10^8,所以说单精度浮点数的有效位数是7位。扩展资料:单精度浮点数是用来表示带有小数部分的实数,一般用于科学计算。在计算机存储器中占用4个位元(32 bits)存储空间,包括符号位1位,阶码8位,尾数23位。利用“浮点”(浮动小数点)的方法,可以表示一个范围很大的数值。其数值范围为-3.4E38~3.4E38。单精度浮点数最多有7位十进制有效数字,如果某个数的有效数字位数超过7位,当把它定义为单精度变量时,超出的部分会自动四舍五入。单精度浮点数的指数用“E”或“e”表示。
Q5:实数真值“2.5”如果用单精度规格化浮点数据格式表达,其编码是什么?
C是这样定义单精度数据的——共有32二进制位,1位符号位+8位阶码(小数点要移动的位数)+23位尾数:最高位是符号位,1表示负数,0表示正数。这里-2.5,所以取1。接着是8位阶码,阶码用移码表示,最高位为符号,0表负、1表正;单精度要在原值上+127实现,即加01111111。把尾数原码接着写在后面,无限小数写够23位即可。注意原码都要化成以1打头(就是小数点移到第一个有效1之后,恢复时小数点应该向哪个方向移几位由阶码表示),并把小数点前面的1省写即可。对于-2.5具体是这样转换的:求尾数:2.5的二进制原码是10.1,变成1.01并省去小数点前面的1为01,01就是尾数。求阶码:由1.01恢复为10.1小数点要向右移一位,所以阶码符号为1(正)、移值为0000001;0000001+1111111=10000000。这就是-2.5的阶码。求全码:1+10000000+01-->11000000 00100000 00000000 00000000——后面的0是补上的,因为小数点后的0实际无数学意义,但C中要补齐32位。最后11000000 00100000 00000000 00000000这个数就是-2.5的格式化表达。不知你问的是不是这个意思。
Q6:求问这个计算机编码怎么做
它是用js脚本还是哪种编程语言实现的?