二进制补码

二进制补码

计算机存储数据都是以0,1二进制进行存储。
对于有符号整数存储(对于浮点数待续),引入补码概念。

原码即直接将真值转换为其相应的二进制形式,而反码和补码是对原码进行某种转换编码方式。
对于正整数, 原码,反码和补码都相一样
对于负整数, 补码等于反码加1,而反码等于原码除符号位不变其他位按位求反


以byte为例,
1 byte 等于 8bit,也就是8个二进制,
最高位0代表正数,1代表负数。
所以对于8位的二进制所有全排列: 0000 0000 -> 1111 1111 一共 2^8 = 256, 即可以表示256个整数(-128 -> 0 -> 127)


 整数         原码          反码     补码
            
-128    1000 0000    1111 1111    1000 0000
-127    1111 1111    1000 0000    1000 0001
-126    1111 1110    1000 0001    1000 0010
***            
-1        1000 0001    1111 1110    1111 1111
0        0000 0000    0000 0000    0000 0000
1        0000 0001    0000 0001    0000 0001
***            
127        0111 1111    0111 1111    0111 1111


采用补码的原因如下。

    
    二补数(2's complement)/补码 系统的最大优点是可以在加法或减法处理中,不需因为数字的正负而使用不同的计算方式。只要一种加法电路就可以处理各种有号数加法,
    而且减法可以用一个数加上另一个数的二补数来表示,因此只要有加法电路及二补数电路即可完成各种有号数加法及减法,在电路设计上相当方便。

    采用补码运算具有如下两个特征:

    1)因为使用补码可以将符号位和其他位统一处理,同时,减法也可以按加法来处理,即如果是补码表示的数,不管是加减法都直接用加法运算即可实现。
    
        3-1 :
            0000 0011
          + 1111 1111
          -------------
           10000 0010 -> 忽略 符号位前1位 即 0000 0010 -> 2
    
    2)两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

    这样的运算有两个好处:

        1)使符号位能与有效值部分一起参加运算,从而简化运算规则。从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来。)

        2)加法运算比减法运算更易于实现。使减法运算转换为加法运算,进一步简化计算机中运算器的线路设计。


### 二进制补码的概念与计算方法 #### 补码的定义 在计算机中,补码用于表示带符号的二进制数。正数的补码与其原码相同,而负数的补码是通过对其绝对的反码加1得到的。这种表示方法解决了反码中零有两个表示的问题,并且使得加减法运算更加简便[^3]。 #### 补码的计算步骤 对于一个给定的十进制整数(包括正数和负数),其二进制补码可以通过以下方式计算: 1. **正数的补码**:直接将其转换为二进制形式即可,符号位为0。 2. **负数的补码**: - 首先将该负数的绝对转换为二进制形式。 - 对二进制数逐位取反(即0变为1,1变为0)。 - 在取反后的结果上加1。 #### 示例计算 以下是一个具体的例子,展示如何计算二进制补码: - **十进制数:-5** 1. 将5转换为8位二进制:`00000101`。 2. 对二进制数逐位取反:`11111010`。 3. 在取反结果上加1:`11111011`。 因此,-5的8位二进制补码为`11111011`。 #### 代码实现 以下是一个C++程序,用于输出任意整数的32二进制补码表示: ```cpp #include <bits/stdc++.h> using namespace std; int main() { long long n; int a[32] = {}; scanf("%lld", &n); if (n < 0) { a[31] = 1; // 符号位设为1 n = 0 - n; // 取绝对 } int i = 0; while (n) { a[i++] = n % 2; n /= 2; } if (a[31] == 1) { // 如果是负数 for (int i = 0; i < 31; i++) a[i] = 1 - a[i]; // 取反 int x = 1; for (int i = 0; i < 31; i++) { // 加1 a[i] = a[i] + x; x = a[i] / 2; a[i] = a[i] % 2; } } for (int i = 31; i >= 0; i--) printf("%d", a[i]); return 0; } ``` #### 补码的应用 补码不仅简化了加减法运算,还使得硬件设计更加高效。例如,在计算机中,两个数的减法可以通过将被减数与减数的补码相加来实现,从而避免了专门设计减法器的需要[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值