黑马程序员技术交流社区
标题:
负数的二进制
[打印本页]
作者:
乌托邦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