黑马程序员技术交流社区

标题: 负数的二进制 [打印本页]

作者: 乌托邦619    时间: 2015-4-14 19:48
标题: 负数的二进制
求解 1111 1111 1111 1111 1111 1111 1111 1010 这个二进制数是负6 的二进制   可是按二进制转十进制  各个为位乘以基数2的幂数相加  这貌似是个很大的数啊 不是负6啊 什么情况
作者: thoris    时间: 2015-4-14 20:12
本帖最后由 thoris 于 2015-4-14 20:39 编辑

负数=正数取反+1
所以要得到正数  先要把负数减一 再取反。
负数是不能直接用次幂去算的
作者: thoris    时间: 2015-4-14 20:41
thoris 发表于 2015-4-14 20:12
负数=正数取反+1
所以要得到正数  先要把负数减一 再取反。
负数是不能直接用次幂去算的 ...

竟然加分了。。。补充一下    正数的二进制是0开头的   首位是1的表示是负数,算法如上。
作者: fanyun2009    时间: 2015-4-14 21:43
正数在计算机中是以原码来存储,负数在计算机中是以补码的形式存储(补码=反码+1)
1111 1111 1111 1111 1111 1111 1111 1010补码,该数是负数
1111 1111 1111 1111 1111 1111 1111 1001反码
0000 0000 0000 0000 0000 0000 0000 0110原码,该数的绝对值6=1*2+1*4
所以1111 1111 1111 1111 1111 1111 1111 1010是-6在计算机中存储的二进制码
作者: huanghe1103    时间: 2015-4-14 21:54
楼上的说的好详细,我就看看好了  :victory:
作者: zhw634631    时间: 2015-4-14 22:00
我就来看一下,学一点




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2