无符号数相减问题 C语言

本文通过一个简单的C语言程序实例,详细解释了当使用无符号整型进行减法运算时,计算机内部如何通过补码实现这一过程,并给出了具体的二进制运算步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

int main()
{
    unsigned int a=50;
    unsigned int b=100;
    printf("%u",a-b);
    return 0;
}

结果是4294967246

为什么呢?

实际上  CPU里只有加法器  没有减法器   做a-b运算时,实际上是做了a+(~b)

因为计算机运算采用补码运算

a-b=a[补码]+(-b)[补码]

50的二进制是:                00000000|00000000|00000000|00110010
100的二进制是:           00000000|00000000|00000000|01100100

50的补码是                      00000000|00000000|00000000|00110010

-100的补码是                    11111111|11111111|11111111|10011100

补码相加得到的结果是           11111111|11111111|11111111|11001110=4294967246

由于a-b得到的是无符号整形,所以原码与补码相等  结果自然为4294967246



评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值