二进制略讲

一、二进制

  1. 二进制略讲

说明:

二进制的每一位全部由0或1组成,就像我们所熟悉的十进制一样每一位全部由0~9组成

示例:二进制转换为十进制(从右往左,按位乘以2的倍群的加和)

  • (0101)2 = 1*20 + 0*21 + 1*22 + 1*23 = 9

  • (1011)2 = 1*20 + 1*21 + 0*22 + 1*23 = 11

推广:n进制转换为十进制

  1. n=7
    • (6056)7 = 6*70 + 5*71 +0*72 + 6*73
  2. n=9
    • (7872)9 = 290 + 791 +8*72 + 7*73

二、补码、原码、反码

  1. 补码、原码、反码(均为二进制)
  1. 机器数就是8位二进制,第一位代表的符号位。
  2. 机器数带符号:正数最高位为0,负数最高位为1
    • 正数:01000001 = 1*20 + 1*26 = 65
    • 负数:11000001 = -(1*20 + 1*26)= -65
  1. 原码:符号位加上真值的绝对值

    • 65,正数,符号位为0,真值的绝对值1000001,则65的原码为01000001
    • -65,负数,符号位为1,真值的绝对值1000001,则-65的原码为11000001
  2. 反码:

    • 正数的反码是其本身
      • 65,正数,其反码为其本身01000001
    • 负数的反码就是在其原码的基础上,符号位不变,其余各位取反(除符号位外,其余位0变1,1变0)
      • -65,负数,其反码为10111110
  3. 补码:

    • 正数的补码就是其本身
      • 65,正数,其补码为其本身01000001
    • 负数的补码就是在原码的基础上,符号位不变,其余各位取反,最后 +1。即,在反码的基础上加1
      • -65,负数,其反码为10111110,补码为10111111

    注:反码加1,不是末位变1,而是在末位加上1,因为是二进制,每位最大不能超过1,就像十进制一

    样,每位最大不超过9,超果之后就得往前进1位,所以若反码末位为0,加1后末位为1,不超过1,不

    进位,若反码末位为1,加1后末位为2,超过1,发生进位。

    eg:-64,原码为11000000,反码为10111111,其补码为11000000,末位加1超过1,发生进位,高位

    接受低位的进位也超过1,继续进位。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值