原码、反码和补码
原码/反码/补码计算器,在线计算给定整数的原码/反码/补码。
工具链接:http://www.atoolbox.net/Tool.php?Id=952
链接: http://www.atoolbox.net/Tool.php?Id=952
数据在计算机中是以其补码形式存储和运算的。
正数的原码、反码、补码均相同。
原码:用最高位表示符号位,其余位表示数值位的编码称为原码。其中,正数的符号位为 0,负数的符号位为 1。
负数的反码:把原码的符号位保持不变,数值位逐位取反,即可得原码的反码。
负数的补码:在反码的基础上加 1 即得该原码的补码。
例如:
+11 的原码为: 0000 1011
+11 的反码为: 0000 1011
+11 的补码为: 0000 1011
-7 的原码为:1000 0111
-7 的反码为:1111 1000
-7 的补码为:1111 1001
注意,对补码再求一次补码操作就可得该补码对应的原码。
#include#include void main { //反码计算步骤 char num_char=0x81; //1000 0001 -1;反码应该是1111 1110 0xfe printf("%xn",num_char); if(num_char<0) { num_char <<=1; printf("<<=1 %xn",num_char); num_char >>=1; printf(">>=1 %xn",num_char); num_char =~ num_char;printf("~ %xn",num_char); //1111 1110 num_char |=0x80; } else { ; } printf("反码=%xn",num_char); //补码计算步骤 num_char=0x81; //1000 0001 -1;补码应该是0xff //printf("%xn",num_char); if(num_char<0) { num_char <<=1; printf("<<=1 %xn",num_char); num_char >>=1; printf(">>=1 %xn",num_char); num_char =~ num_char;printf("~ %xn",num_char); //1111 1110 num_char += 1; printf("+= 1 %xn",num_char); num_char |=0x80; } else { ; } printf("补码=%xn",num_char); }



