为什么负数取补码啊

来源:学生作业帮助网 编辑:作业帮 时间:2024/10/03 07:55:44
为什么负数取补码啊
xWRY~O% *wX53kZ (1v(c4$4ȿ$}N7O¬}vslDTk.>ok_z \XCYRDimݟzbDGӘ-O?_wՋX;͒s^;WsÃ7(J;OahZ]ɚXb0և}1 +_t!Jf͛>. WnzSW-imf&h|=ƻlMD .[%-PTE='͑LTKX ۑ;UnCw^\ܪo B\[d?ɣ+r9q;qU g!5Nzvv>0¶ As[^{ikbɒrb3^y$SX+-K[r1C)Ϗiu&*wZٳ{ qˎ,0? sKR0s<17K`*dF"bd&~ͬ B9ࠬ4;w?Q_0SF6fh}|9$1^Xx_RVċK(ʹofOC\M Da ~SK/M=@&$;e3.%2Kn`.}(22XTZ`nRH:)vqS`$fZrey 68Q)\g L\]B%sDaEip~-6\ ~J$W4M9V+$SaӲyT1T`J\/SA/{ C3VWV|ӈWCZԈi*K1BGl-> ;= ң.[Dq˺|=>9=B dyV]7N~/.>7|R' O Nd;wn?J0} ޘq|bA1sኧ~ b|P cIwq ( ,|S@hzHE%"ytu`feͨfP[A no }<.m=1Qa(|f4 peW<gi-Qld}:O>7a(qT {@̞gE[H^ʴؙ4\ba"?LƢŌI<1k=!FLcvFI$I@e7D|_)ŀZſ\(Z@0bRxiRnvz ,'  `q ݡY5vs xUA/&${LbuClgJ e<OO)^Z O'Yl_";kH

为什么负数取补码啊
为什么负数取补码啊

为什么负数取补码啊
因为没-0嘛

加法器
计算机里面,只有加法器,没有减法器,所有的减法运算,都必须用加法进行。
即:减去某个数字(或者说加上某个负数)的运算,都应该研究如何用加法来完成。
模、补数
在日常生活当中,可以看到很多这样的事情:
把某物体左转 90 度,和右转 270 度,在不考虑圈数的条件下,最终的效果是相同的;
把分针倒拨 20 分钟,和正拨 40 分钟,在不考虑时针...

全部展开

加法器
计算机里面,只有加法器,没有减法器,所有的减法运算,都必须用加法进行。
即:减去某个数字(或者说加上某个负数)的运算,都应该研究如何用加法来完成。
模、补数
在日常生活当中,可以看到很多这样的事情:
把某物体左转 90 度,和右转 270 度,在不考虑圈数的条件下,最终的效果是相同的;
把分针倒拨 20 分钟,和正拨 40 分钟,在不考虑时针的条件下,效果也是相同的;
把数字 87,减去 25,和加上 75,在不考虑百位数的条件下,效果也是相同的;
……。
上述几组数字,有这样的关系:
  90 + 270 = 360
  20 + 40 = 60
  25 + 75 = 100
式中的 360、60 和 100,就是“模”。
式中的 90 和 270、20 和 40,以及 25 和 75,就是一对对“互补”的数字。
知道了“模”,求某个数字的“补数”,就是轻而易举的了:
如果模为 365,数字 120 的补数为:365 - 120 = 245。
用补数代替原数,可把减法转变为加法。出现的进位就是模,此时的进位,就应该忽略不计。
二进制数的模
前面说过的十进制数 25 和 75,它们是 2 位数的运算,模是 100,即 1 的后面加上 2 个 0。
如果有 3 位数参加运算,模就是 1000,即 1 的后面加上 3 个 0。
这里的 1000,是十进制数的一千,可以写成 10^3,即 10 的 3 次方。
推论:有多少位数参加运算,模就是在 1 的后面加上多少个 0。
对于二进制数字,模也是这样推算。
如果是 3 位二进制数参加运算,模就是 1000,即 1 的后面加上 3 个 0;
那么当 8 位二进制数参加运算,模就是 1 0000 0000,即 1 的后面加上 8 个 0。
16 位二进制数参加运算,模可就大了,是 1 的后面加上 16 个 0。
注意:这里提到的 1、0,都是二进制数。
8 位二进制数的模可以按照十进制写成 2^8,即 256。
16 位数二进制数的模,就是 2^16,按照十进制,它就是 65536。
二进制数的补码
求二进制数的补数,目的是往计算机里面存放。
在计算机里面,存放的数字什么的,都称为机器码;那么二进制形式的补数,也就改称为补码了。
一般情况下,都是以 8 位二进制数来讨论补码,少数也有用 16 位数的。
计算时加上正数,是不需要进行求取补数的;只有进行减法(或者加上负数),才需要对减数求补数。
补码就是按照这个要求来定义的:正数不变,负数即用模减去绝对值。
已知一个数 X,其 8 位字长的补码定义为:
      / X 0 <= X <= +127 ;正数和0的补码,就是该数字本身
 [X]补 = |
      \ 2^8 -|X| -128 <= X < 0 ;负数的补码,就是用 1 0000 0000,减去该数字的绝对值
例如 X = -126,其补码为 1000 0010,计算方法如下:
    1 0000 0000
   - 0111 1110
 -----------
     1000 0010
可以看出,按照补码的定义来求补码,概念十分清晰,方法、步骤也是十分简单的。

收起

为什么负数取补码啊 负数取补码产生溢出怎么处理?比如原码为10000000 取补码后是什么? 关于负数取补码的问题,搞不懂这个, 负数的补码F6H(负数)的补码? 负数的原码、反码、补码负数的补码,-1,取反,得到原码a1负数的补码,取反,+1,得到原码a2a1与a2为什么相等感谢“做而论道”,你写的很好.其中,很好的一点是你引入了模的概念,而很多地方却以0 为什么二进制编码负数的绝对值是补码? 二进制负数的补码的原理 为什么要用补码的形式改更负数如何掌握它的用法? 为什么能取负数 二进制负数的绝对值怎么求用二进制表示的负数的绝对值的求法,是不是取它的补码就可以了呢,可是负数的补码第一位符号位不变啊,绝对值不应该是正的吗,准确来说是不是应该把二进制负数 C语言中 负数在内存中为什么要以补码形式存储? byte 最大数为127 为什么不是128基本搞清楚负数为 补码加1 为什么正数的补码等于原码,是程序编码时将负数进行取补而正数不操作,还是取补对正数不影响?老师只是说正数的补码等于原码,难道计算机也是这么说的? 关于减法补码的一些问题?这是补码公式:为什么2的次方数是4呢?,求负数的结果是【x1】补=1.0010的取反在加1吗,然后为什么又加0.0001呢?我就是15分了 负数,原码变补码是取反加一,但补码变原码也是取反加一? 计算机内为什么用补码出存啊?为什么运算是用的是补码啊? C语言中 负数0负数原码为1000000000000000的补码问题上面的原码的补码,求时原码1000000000000000 除符号位1取反1111111111111111 然后加1 不就变成 10000000000000000 不跟正数0的 java 中为什么两个负数取余结果还是负数? 为什么补码的补码等于源码?