美文网首页十天学会C语言
第06天C语言(03):原码补码反码

第06天C语言(03):原码补码反码

作者: liyuhong | 来源:发表于2017-07-08 12:03 被阅读48次
一、概念
/*
 为什么要有 原码 / 反码 / 补码 ? 主要是为了方便计算机计算
 其实二进制的第一位 是二进制的符号位
 如果该位是0 代表这个数 是正数
 如果该位是1 代表这个数 是负数
 
 正数
 总之一句话, 正数的原码\补码\反码 都是一样的,三码合一
 负数
 反码 : 符号位不变, 其他位取反(0变1,1变0)
 补码 : 反码 + 1就是补码
 
 9的二进制
 正数
 0000 0000 0000 0000 0000 0000 0000 1001 (原码)/反码/补码
 负数
 1000 0000 0000 0000 0000 0000 0000 1001 (原码)
 1111 1111 1111 1111 1111 1111 1111 0110 (反码)
 1111 1111 1111 1111 1111 1111 1111 0111 (补码)


 // 补码的深入
 1 - 1 = 1 + (-1)
 原码 计算结果 = -2
 反码 计算结果 = -0
 补码 计算结果 = 0
 
 */
二、代码
#include <stdio.h>
int main()
{
    // 其实,数据存储在内存中都是存储的二进制
    // 二进制 又可以分为 原码 / 反码 / 补码
    // 其实最终存储在内存的 是 "补码"
#pragma 2.正数

    /*
//    9 --> 存储在内存中的 ---> 二进制
//    9是整形 == int  == 4个字节 == 1个字节等于8位 == 整形有32位
     1001
     
    0000 0000 0000 0000 0000 0000 0000 1001 (原码)
    什么是反码 , 正数的反码 就是正数的原码
    什么是补码 , 正数的补码 就是正数的原码
    总之一句话, 正数的原码\补码\反码 都是一样的,三码合一
     */
    
#pragma 2.负数
    /*
     -9 --> 存储在内存中的 ---> 二进制
     其实二进制的第一位 是二进制的符号位, 
     如果该位是0 代表这个数 是正数
     如果该位是1 代表这个数 是负数
     1000 0000 0000 0000 0000 0000 0000 1001 (原码)
     反码 : 符号位不变, 其他位取反(0变1,1变0)
     1111 1111 1111 1111 1111 1111 1111 0110 (反码)
     补码 : 反码 + 1就是补码
     
     1111 1111 1111 1111 1111 1111 1111 0110 (反码)
+    0000 0000 0000 0000 0000 0000 0000 0001   +1
     ------------------------------------------
     1111 1111 1111 1111 1111 1111 1111 0111  (补码)

     */
    
    /*
     -15 的 原码 / 反码 / 补码
     1000 0000 0000 0000 0000 0000 0000 1111 (原码)
     1111 1111 1111 1111 1111 1111 1111 0000 (反码)
     1111 1111 1111 1111 1111 1111 1111 0001 (补码)
     
     为什么要有 原码 / 反码 / 补码 ? 主要是为了方便计算机计算
     1.由于最高位是符号位,如果是 0 就代表是正数, 如果是1 就代表是 负数
     2. 那么如果直接存储原码,计算机在计算的时候 还需要先判断最高位才能计算,效率低
     3. 为了方便计算机计算,所以有了反码 和 补码, 有了反码和补码之后, 以后计算机就不需要判断最高位了,直接计算就可以了
     
     1 + 1 
     0001
     0001
     ----
     0010 == 2
     
     1 - 1  == 1 + (-1) 计算机只会做加法
     0000 0001 (原码)
    +1000 0001 (原码)
     ----------
     1000 0010 == -2
     
     
     1 - 1 = 1 + (-1)
     0000 0001 (原码) (反码)
    +1110 1110 (反码)
     -----------
     1111 1111  == (反码) 然后反码转换为原码(符号位不变,其他0变1,1变0) == 1000 0000(原码)
     将计算机出来的反码转换为 原码 ,在将原码 转换为十进制
     1000 0000 == (原码) == -0
     
     1 - 1 = 1 + (-1)
     0000 0001 (+1补码)
    +1111 1111 (-1补码)
     -----------
    10000 0000 == 0
     */
    
    return 0;
}

相关文章

  • 软件测评师做题技巧

    第一类补码,反码,原码 正数:原码=反码;补码=原码负数:反码=原码求反;补码=反码+1 第二类用例概率的计算 测...

  • 原码、反码、补码和移码

    书中关于原码、反码、补码和移码的定义如下(n是机器字长):原码: 反码: 补码: 移码: 原码, 反码, 补码的基...

  • 2018-10-22 Python31 原码、反码、补码

    原码、反码、补码 1)如何计算补码?规则: 正数:原码 = 反码 = 补码负数:反码 = 符号位不变,其他位取反补...

  • 计算机为什么要使用原码、反码、补码

    1. 什么是原码、反码、补码 先看一个例子: +1和-1的原码、反码、补码的表示 原码、反码、补码的计算方式如下:...

  • 补码

    原码、反码、补码 原码:符号位 反码:减法变加法 补码:+1解决-0问题 数学原理 同余 反码:mod127 补码...

  • C语言 原码、反码、补码

    原码:最高位为符号位,其余各位为数值本身的绝对值。 反码:正数的反码与原码相同;负数的反码,符号位为1,其余位对原...

  • 【计算机】我的收藏文章索引

    索引表 索引标题链接摘要原码、反码、补码《原码、反码、补码,详解》http://www.cnblogs.com/z...

  • [计基]-二进制之补码

    一.基础名词 原码 : 0011 反码 :0011(原码) >> 1100(反码) (原码按位取反) 补码 :00...

  • 技术问 - 原码、反码、补码

    什么是原码、反码、补码:

  • 位运算

    1.原码、反码、 补码正数的原码、反码、 补码都一样 正数以原码存储在计算机负数 以补码存储在计算机 例...

网友评论

    本文标题:第06天C语言(03):原码补码反码

    本文链接:https://www.haomeiwen.com/subject/clwdhxtx.html