• 【计组】为什么计算机采用补码进行运算?


    引入:现有一个时钟,指向9点,那么四个小时后将指向几点?
    显而易见四小时后时钟将指向1点。

    时钟构成了一个模12计数器。如果将0点当作一个边界,那么9点或许可以用另一个说法叫-3点,我们可以通过-3+4=1得到1,也可以通过9+4=13再模12得到1,这就是计算机采用补码进行运算原理的一个比较好理解的解释。

    下面进行解释:

    如果符号不同的两个数的绝对值相加等于模,则称这两个数互为补数。

    1)一个负数可用它的正补数来代替,而这个正补数可以用模加上负数本身来得到。一个正数和一个负数互为补数时,两数的绝对值之和为模。
    2)正数的补数为其自身。

    在时钟的例子里,我们要计算-3+4,就可以转换为寻找-3的补数9,将9+4,将结果取模的过程。

    类比到计算机中,如果两个正数相加,这再好不过,直接相加即可。如果不幸为一正一负相加或两个负数相加,如果采用原码进行计算,就繁琐的多。所以我们采用补码进行计算,为简略表示我们用四位数来表示补码。

    如果计算0110(原)与1011(原)相加
    首先我们求出1011的补码1,101(补)
    这里我们不妨看看1011和1,101相加会发生什么(抛掉符号位,即取绝对值0011+1,101=10000,发现向前进了一位,但是计算机中的位数是固定的,这个位数会被舍弃掉(自动取模)。我们回到补数的定义:如果符号不同的两个数的绝对值相加等于模,则称这两个数互为补数。

    其实对负数求补码,就是求负数的补数,用正数的加法替代减法。

    这时我们将0110与1011的补码1101相加,得10011,因为我们只有四位,所以最高位将被舍弃(相当于自动取模,13点取模后为1点),所以结果为0011,即3。

  • 相关阅读:
    程序员都应该懂Kubernetes的基本概念和关键组件是什么吗?
    汽车保养笔记
    描述一下锁的四种状态及升级过程?
    【前端指南】session和token
    JAVA开发 使用Apache PDFBox库生成PDF文件,绘制表格
    PayPal账户遭大规模冻结!跨境卖家如何自救?
    python实现对遥感影像经纬度获取并实现海陆分离
    图问题——深度遍历,广度遍历,并查集
    算法-有效括号
    python:bisect查找和排序
  • 原文地址:https://www.cnblogs.com/exungsh/p/15943278.html