马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有账号?立即注册
x
目次
一、原码
二、反码
三、补码
示例1:
示例2:
在计算机范畴中,原码、反码和补码是用来表示有符号整数的三种不同的编码方式。
一、原码
原码是最直观的一种表示方法,即用最高位表示符号位,0表示正数,1表示负数,其余位表示数值的大小。例如,十进制数+3的原码为00000011,十进制数-3的原码为10000011。
二、反码
反码是为了办理原码运算中出现的零有两种表示方法的问题而引入的。正数的反码与原码相同,负数的反码是将原码中除符号位外的所有位取反。例如,十进制数+3的反码为00000011,十进制数-3的反码为11111100。
三、补码
补码是为了办理原码负数相加发生溢出时无法正确表示的问题而引入的。正数的补码与原码相同,负数的补码是将原码中除符号位外的所有位取反,然后再加1。例如,十进制数+3的补码为00000011,十进制数-3的补码为11111101。
示例1:
- #include <stdio.h>
- void printBinary(int num) {
- for (int i = 7; i >= 0; i--) {
- printf("%d", (num >> i) & 1);
- }
- printf("\n");
- }
- int main() {
- int num = -3;
- // 原码
- printf("原码表示:\n");
- printBinary(num);
- // 反码
- int neg_num = num < 0 ? (~num) : num;
- printf("反码表示:\n");
- printBinary(neg_num);
- // 补码
- int twos_complement;
- if (num < 0) {
- twos_complement = (~num) + 1;
- } else {
- twos_complement = num;
- }
- printf("补码表示:\n");
- printBinary(twos_complement);
- return 0;
- }
-
复制代码
示例2:
- #include <stdio.h>
- void printBinary(int num) {
- for (int i = 7; i >= 0; i--) {
- printf("%d", (num >> i) & 1);
- }
- printf("\n");
- }
- int main() {
- int num1 = 5; // 正数的情况
- // 原码
- printf("数字 %d 的原码表示:\n", num1);
- printBinary(num1);
- // 反码
- printf("数字 %d 的反码表示:\n", num1);
- printBinary(num1);
- // 补码
- printf("数字 %d 的补码表示:\n", num1);
- printBinary(num1);
- printf("\n");
- int num2 = -8; // 负数的情况
- // 原码
- printf("数字 %d 的原码表示:\n", num2);
- printBinary(num2);
- // 反码
- int neg_num2 = num2 < 0 ? (~num2) : num2;
- printf("数字 %d 的反码表示:\n", num2);
- printBinary(neg_num2);
- // 补码
- int twos_complement2;
- if (num2 < 0) {
- twos_complement2 = (~num2) + 1;
- } else {
- twos_complement2 = num2;
- }
- printf("数字 %d 的补码表示:\n", num2);
- printBinary(twos_complement2);
- return 0;
- }
-
复制代码 以上代码示例中,起首界说了一个函数printBinary用于将一个整数以二进制情势打印出来。然后在main函数中,将一个整数-3作为示例输入,分别输出了其原码、反码和补码表示。您可以在编译器中运行该代码,查看结果。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |