C语言实现原反补相互转换

C语言实现原反补相互转换

1.原码、反码、补码

符号位:一个有符号定点数的最高位为符号位,0是正,1是负。

原码:最高位为符号位,其余各位为数值本身的绝对值。

反码:正数的反码与原码相同,负数的反码,符号位为1,其余位对原码取反。

补码:正数的补码与原码相同;负数的补码,符号位为1,其余位对原码取反加1。

2.举例:

数据原码反码补码
10000 00010000 00010000 0001
-11000 00011111 11101111 1111
00000 00000000 00000000 0000
-26100000000000000000000000000110101111111111111111111111111110010111111111111111111111111111100110

3.代码实现

#include <stdio.h>

/* 根据要判断的符号位来更改下面的移位操作! */

/* 原码转补码 */ 
int original_2_complement(int x ) 
{
    int y ,res;
    y = x >> 18 ;
   
    res = x;
   	/* 负数 */
    if(y)
    {    	    
	    res = (~x + 1) - (1<<19) ;
		res = -(res & 0x3ffff);
	}	
    return res;
}




int main(void) 
{ 
	
	int yuanma;
	
	yuanma = get(0x3142f);
	
	printf("%d = yuanma\r\n",yuanma); 	

	return 0;
}

4.原码和补码的使用

​ 原码:使用原码来进行计算

​ 补码:使用补码来进行存储

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值