将负数转化为补码(负数的原码转换为补码)

http://www.itjxue.com  2023-01-26 12:36  来源:未知  点击次数: 

负数的补码怎么求?

求负数的补码,通常都是说:先求原码、再取反加一。

但是,原码,是有缺陷的。

因为,天下只有一个零。而在原码中,却编造了两个码:+0、-0。

所以,八位原码的表示范围,只能是:-127~+127。

而在八位的补码中,只有一个零,所以就多出一个:-128。

用“取反加一”的方法,求-0 和-128 的补码,这就尴尬了!

求-0 的补码,得出的是 0000 0000。

符号位竟然是 0 !  难道,-0,是正数吗?

求-128 的补码,更是无处下嘴。

其实,取反加一,并没有什么道理。也可以说,这是错误的。

---------------------

补码,其实,是一个“代替负数”的正数。

使用了补码之后,在计算机中,就没有负数了。

同样,在计算机中,也就没有减法运算了。

利用补码,就是把加减法,统一为加法运算。

使用补码的目的,就是简化计算机的硬件。

---------------------

补码(一个正数),怎么就能代替负数呢?

你看时针,倒拨 3 小时,可以用正拨 9 小时代替。

你看三角函数,-π/2、+3π/2,两者函数值也是相等的。

如果限定,只用 2 位 10 进制数,那么有:

 25 - 1 = 24

 25 + 99 = (一百) 24

如果忽略进位一百(10^2),+99 就和-1 等效。

上面这些正数,就是负数的补数。

求补数的计算公式:?补数(即正数) = 负数 + 周期。

而正数,不可变换,必须直接参加运算。

所以,正数,就没有补数。

---------------------

计算机用二进制,就称为补码了。

8 位 2 进制,周期是:2^8 = 256。

-1 的补码,就是:-1 + 256 = 255 = 1111 1111(二进制)。

-2 的补码,是:254 = 1111 1110。

。。。

-128 的补码是:128 = 1000 0000。

此时,楼主的问题,就解决了。

补码的定义式:

 X = 0,? [ X ]补 = X;正数不用变换。

 X 0,  [ X ]补 = X + 2^n。 n 是补码的位数。

按此公式求补码,是极为简便的,而且还能理解补码的意义。

---------------------

那么,就不要学“原码反码取反加一符号位不变”了。

老外数学不好,也只能摆弄哪些“隔,路”的花样。

负数原码变补码

在计算机中,数的正负号是用0,1表示。

真值为正时。其原码,反码,补码完全相同。

如:真值=+0101010,

原码=反码=补码=00101010

真值为负时,其原码就是把负号改为1,其余不变。反码就是负号改为1,其余取反。补码就是在反码的基础上加1.

加1时记得是逢2进1.

如:真值=-0101010

原码=10101010

反码=11010101

补码=11010110

这上面的就是对原码,反码,补码的解说,希望对你有帮助。你上面举的数,我不知是原码还是反码,所以不解。你可以根据我什么说的,去解就行了。

你如果还有不解的可以联系我!

!!!根据你的补充,是你说的那样,但是要记得先把反码求出来才能求得补码哦!

负数的补码怎么求 负数的补码计算方法

在计算机系统中,数值,一律采用补码表示和存储。

在计算机中,原码和反码,都是不存在的。

求补码,也用不着它们。

所以,原码和反码,根本就没有用!

------------------------

补码,其实,就是一个“代替负数做运算”的正数。

且看 2 位 10 进制数的运算:

 25 - 1 = 24

 25 + 99 = (一百) 24

你舍弃进位,只取两位,这两种算法,功能就完全相同。

那么,+99,就代替了-1。加法,也就代替了减法。

这不就是用正数(补数)代替了负数吗?

由负数求对应的补数,计算公式是: 补数 = 负数 + 10^n。

式中: n 是补数的位数。

 10^n 是 n 位 10 进制数的计数周期。

-------------------------

计算机用二进制,补数,就改称为:补码。

计算机所能计算的位数,是固定的,如八位机、16 位。。。

八位二进制是:0000 0000~1111 1111 (十进制 255)。

八位二进制的计数周期,是:2^8 = 256。

求负数补码的计算公式,也是: 负数 + 周期。

-1 补码就是:-1 + 256 = 255 = 1111 1111(二进制)。

-2 补码就是:-2 + 256 = 254 = 1111 1110(二进制)。

。。。

-128 补码就是:128 = 1000 0000(二进制)。

正数,必须直接参加运算,不许转换。

所以,正数不存在补码。

求补码,根本就不用“原码反码符号位取反加一”。

-------------------------

举例说明,用八位补码计算: 5 - 7 = -2。

 5? = 0000 0101

 -7 的补码= 1111 1001

--相加-------------

 得?  (1)? 1111 1110 = -2 的补码

舍弃进位,只保留八位,这就用加法,实现了 5-7。

(责任编辑:IT教学网)

更多

推荐ASP教程文章