【面试】原码、反码和补码的简单运算

原码(存在正负运算,±0问题)

原码就是早期用来表示数字的一种方式: 一个正数,转换为二进制位就是这个正数的原码。负数的绝对值转换成二进制位然后在高位补1就是这个负数的原码

举例说明:
      int类型的 3 的原码是 11B(B表示二进制位), 在32位机器上占四个字节,那么高位补零就得:
      00000000 00000000 00000000 00000011
      int类型的 -3 的绝对值的二进制位就是上面的 11B 展开后高位补零就得:
      10000000 00000000 00000000 00000011

缺点

  1. 零分两种 +0 和 -0
  2. 在进行不同符号的加法运算或者同符号的减法运算的时候,不能直接判断出结果的正负。你需要将两个值的绝对值进行比较,然后进行加减操作 ,最后符号位由绝对值大的决定。于是反码就产生了。

反码(存在±0问题)

弥补原码加减运算的缺点
正数的反码就是原码,负数的反码等于原码除符号位以外所有的位取反

举例说明:
      int类型的 3 的反码是
      00000000 00000000 00000000 00000011
      和原码一样没什么可说的
      int类型的 -3 的反码是
      11111111 11111111 11111111 11111100
      除开符号位 所有位 取反

补码(无缺点)

弥补正负零的缺点。
反码最低位加1

举例说明:
      int类型的 3 的反码是
      00000000 00000000 00000000 00000011
      和原码一样没什么可说的
      int类型的 -3 的反码是
      11111111 11111111 11111111 11111100
      除开符号位 所有位 取反

例题

一个8位的二进制整数,采用补码表示,且由3个“1”和5个“0”组成,则最小值为多少?
-125
解析:对于补码,正数和原码相同,负数是除开符号位后取反+1。补码的特性,不管正数负数,10进制越大的数对应的二进制也越大

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值