就比如-9补码是11110111。
9的源码为00001001,如果是负数的话,补码为最高位置1,其余取反也就是11110110,然后在最低位加1即可即11110111。
计算机中的负数是以其补码形式存在的补码=原码取反+1。
一个字节有8位可以表示的数值范围在-128到+127。用二进制表示也就是10000000-01111111(注意:最高位表示符号)。最高位是1的都是负数最高位是0的都是正数。
(1)补码相乘计算方法扩展阅读:
补码乘法
补码的乘法不具备【X*Y】补=【X】补×【Y】补的性质。但是【X*Y】补==【X】补×Y,所得结果再取补码,如薯衫x=101,y=011,[x*y]补禅手卜=-[(-101)*011]=-[011*011]=-01001=10111。
其中,若【Y】补=y31y30……y0,则Y=-y31*2^31+y30*2^30+……+y0*2^0
原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为贺穗0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。
Ⅱ 举一个计算机补码计算的例子,以及怎么计算
运用:在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理。
计算
1、正数
正整数的补码是其二进制表示,与原码相同。
例如:+9的补码是00001001。(备注:这个+9的补码是用8位2进制来表示的,补码表示方式很多,还有16位二进制补码表示形式,以及32位二进制补码表示形式,64位进制补码表示形式等。每一种补码表示形式都只能表示有限的数字。)
2、负数
求负整数的补码,将其原码除符号位外的所有位取反(0变1,1变0,符号位为1不变)后加1。
同一个数字在不同的补码表示形式中是不同的。比如-15的补码,在8位二进制中是11110001,然而在16位二进制补码表示中,就是1111111111110001。以下都使用8位2进制来表示。
例如:求-5的补码。-5对应正数5(00000101)→所有位取反(11111010)→加1(11111011)。所以-5的补码是11111011。
3、0的补码
[+0]补=[+0]反=[+0]原=00000000
[ -0]补=11111111+1=00000000
(2)补码相乘计算方法扩展阅读
补码乘法
补码的乘法不具备【X*Y】补=【X】补×【Y】补的性质。但是【X*Y】补==【X】补×Y,所得结果再取补码,如x=101,y=011,[x*y]补=-[(-101)*011]=-[011*011]=-01001=10111。
其中,若【Y】补=y31y30……y0,则 Y=-y31*2^31+y30*2^30+……+y0*2^0
原码
原码(true form)是一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。
Ⅲ 用补码一位乘法计算X*Y的补码,写出计算过程,X=0.1010,Y= -0.0111
X的补码为0.1010,-X的补码为1.0110,Y的补码为1.1001(低位有4位)。
高位
低位(乘数补码处理值)
说明
00
0000
|110010
最低位10,高位加-X的补码
11
0110
————
11
0110
11
1011
01|1001
执行右移,最低位01,高位加X的补码
00
1010
————
00
0101
00
0010
10|1100
执行右移,最低位00,高位加0
00
0000
————
00
0010
00
0001
010|110
执行右移,最低位10,高位加-X的补码
11
0110
————
11
0111
11
1011
1010|11
执行右移,乘数补码被右移出去,进行最后一次
00
0000
运算,最低位11,高位加0
————
11
1011
1010|11
最终结果为11.10111010,因为补码一位乘结果用的是双符号位,换成单符号位就是1.10111010。
我总结了点补码一位乘的方法,给你参考下
处理对象:被乘数补码*乘数补码=两数积的补码。
预处理:
1、单独算出被乘数的相反数的补码,同时乘数补码往右扩一位补0(乘数补码处
理值),积的符号位与其余位必须一同计算。
2、两数补码相乘拆分为多个加法运算。
3、每次加法运算分为高位和低位两部分处理,高位初始值为0、位数是在带符号被乘
数位数基础上向左扩一位(利于右移),低位初始值是乘数补码处理值、位数与乘数
数据位位数相同。
第一次加:4、第一次加法是由高位和加数相加,加数的值由乘数补码处理值的最低两位确定
(若为01,加数为被乘数补码,若为10,加数为被乘数的相反数的补码,若这两位
的数值相等,则加数为0;加数左边多余的一位根据其符号位确定补0还是补1,符
号位为0则补0,符号位为1则补1)。
5、此次加法运算结束后,加法运算所得的高位(部扒旅分积)与低位合成一个整体并右移1
位得到新的高位和低位(右移时左边补0还是补1由右移前的符号位确定,符号位为
0则补0,符号位为1则补1,,另外在右移时乘数补码处理值也连带着右移)。
第二次加:6、高位再次进行加法处兆中理,加数的值由新得到的乘数补码处理值的最低两位确定(确
定方法同第4点)。
7、此次加法运算结束后,加法运算所得的高位(部分积)与低位合成一个整体并右移1
位得到新的高位和低位(右移时高位左边补0或1的确定方法同第5点,另外在右移
时乘数补码处理值也连带着右移)。
循环加法:8、按“第二次加”的方法循环,直至低位将乘数补码处理值的每一位都右移出去后,
再进行一次加法运算(此次加法运算结束后不进行右移),此时得到的高位和低位
合成一个整体就是最终乘积,这个最终乘积是双符号位。
9、所得的最终乘积的小数位数必须是被乘
数补码与乘数补码的小数位数之和。
关于双符号位:00
正,11
负,01
上溢,10
下溢。
附注:无论是原码一位乘,还是补码一位乘、补码二位乘,与手工算法都有共通之处,都是根据
乘数每一位(或两位)
的状态在被乘数的基础上来确定加数(如被乘数、被乘数补码、被
乘数相反数春猜凳补码、0),因为乘数是二进制的,
每一位只有0、1两种状态,所以又免去
了手算十进制乘法中以乘数每一位去乘被乘数来确定加数的过程,而右
移所得的部分
积就相当于手算乘法中左移加数。