C语言----原码、反码、补码

C语言----原码、反码、补码

本文以12和(-12)为例,简要介绍正数和负数的原码、反码、补码求解过程
(注:本文均以C语言中整数int所占4字节32位形式来求解!)

正数原码、反码、补码
1、求解方法:正数的原码 = 反码 = 补码!
2、例子:求解12的原码、反码和补码?
解:12对应的二进制形式为:1100;
原码:0000 0000 0000 0000 0000 0000 0000 1100;
反码:0000 0000 0000 0000 0000 0000 0000 1100;
补码:0000 0000 0000 0000 0000 0000 0000 1100;

负数原码、反码、补码
1、求解方法:
负数原码: 先求该数绝对值对应的原码,再将其最高位的符号位改为1即可;
负数反码:将它的原码形式除了最高位外,其他位上的数都取反,即:0变1,1变0;
负数补码:将它的反码加上1;
2、例子:求解(-12)的原码、反码和补码?
解:(-12)对应的绝对值是12,12的原码如下:
0000 0000 0000 0000 0000 0000 0000 1100;
再将上式最高位变为1即它的原码形式;
所以:
(-12)原码为:1000 0000 0000 0000 0000 0000 0000 1100;
反码由上述求解方法可得(除最高位外,其余0变1,1变0):
(-12)反码为:1111 1111 1111 1111 1111 1111 1111 0011;
补码为反码加1,即:
(-12)补码为:1111 1111 1111 1111 1111 1111 1111 0100;

  • 11
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值