本文主要向大家介绍了C/C++知识点之C语言怎么求得一个32位数的原码补码反码和移码,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。

由于浮点数还需要考虑浮点数的存储方式,所以目前暂时提供正数的补码、反码、移码

源代码如下:

#include 

#include 

#include 

void ShowValueBin(int bits, int value)

{

int i;

for(i = bits-1; i >=0; i--)

{

if(value & (1 <

{

printf("1");

}

else

{

printf("0");

}

}

}

int GetSign(int iNum)//获取符号位

{

int iSign = iNum >> 31;

if(iSign)//高位为1为负数

return 1;

else

return 0;

}

int  Complemental_Code(int iNum)//补码

{

int iSign = GetSign(iNum);

if(iSign)

{

iNum = Ones_complement_Code(iNum)+1;

return iNum;

}

else

{

return iNum;

}

}

int Ones_complement_Code(int iNum)//反码

{

int iSign = GetSign(iNum);

if(iSign)//为负数

{

iNum = ~iNum;

iNum |= 1 <

return iNum;

}

else

{

return iNum;

}

}

int Frame_Shift(int iNum)//移码

{

int iSign = GetSign(iNum);

if(iSign)

{

iNum &= ~(1 <

return iNum;

}

else

{

iNum |= 1 <

return iNum;

}

}

int True_Code(int iNum)

{

int iSign = GetSign(iNum);

if(iSign)//负数在内存中是以补码的形式存在

{

iNum = Complemental_Code(iNum);

return iNum;

}

else

{

return iNum;

}

}

int main(int argc, char* argv[])

{

/*****************************************************

1. 正数:

正数的原码、反码、补码都相同。

2. 负数:

原码:负数的绝对值,并且最高位为1。

反码:原码的符号位不变,其他位按位取反。

补码:在反码的基础上+1。

3. 移码:

无论是正/负数,都是在补码的基础上,符号位取反。

******************************************************/

int True_Code1 = True_Code(4);

int True_Code2 = True_Code(-4);

int Complemental_Code1 = Complemental_Code(4);

int Complemental_Code2 = Complemental_Code(-4);

int Ones_complement1 = Ones_complement_Code(4);

int Ones_complement2 = Ones_complement_Code(-4);

int Frame_Shift1 = Frame_Shift(4);

int Frame_Shift2 = Frame_Shift(-4);

printf("True_Code1=%d\r\n", True_Code1);

printf("True_Code2=%d\r\n", True_Code2);

printf("Complemental_Code1=%d\r\n", Complemental_Code1);

printf("Complemental_Code2=%d\r\n", Complemental_Code2);

printf("Ones_complement1=%d\r\n", Ones_complement1);

printf("Ones_complement2=%d\r\n", Ones_complement2);

printf("Frame_Shift1=%d\r\n", Frame_Shift1);

printf("Frame_Shift2=%d\r\n", Frame_Shift2);

printf("\r\n");

ShowValueBin(32, 4);

printf("\r\n");

ShowValueBin(32, -4);

printf("\r\n");

return 0;

}

结果如下:

True_Code1=4

True_Code2=-2147483644

Complemental_Code1=4

Complemental_Code2=-2147483644

Ones_complement1=4

Ones_complement2=-2147483645

Frame_Shift1=-2147483644

Frame_Shift2=2147483644

00000000000000000000000000000100

11111111111111111111111111111100

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标编程语言C/C+频道!

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐