源码1的1位反码是什么_一个数的反码的反码是原码本身

hacker|
96

文章目录:

-1的原码,补码,反码是什么??

机器数一个数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1.比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011。如果是 -3 ,就是 10000011 。那么-1,就是10000001

原码

如果机器字长为n,那么一个数的原码就是用一个n位的二进制数,其中最高位为符号位:正数为0,负数为1。剩下的n-1位表示该数的绝对值。

例如:

X=+101011 , [X]原= 0010_1011

X=-101011 , [X]原= 1010_1011

位数不够的用0补全。

PS:正数的原、反、补码都一样,0的原码跟反码都有两个,因为这里0被分为+0和-0。

反码

知道了原码,那么你只需要具备区分0跟1的能力就可以轻松求出反码,为什么呢?因为反码就是在原码的基础上,符号位不变其他位按位取反(就是0变1,1变0)就可以了。

例如:

X=-101011 , [X]原= 1010_1011 ,[X]反=1101_0100

补码

补码也非常的简单,就是在反码的基础上按照正常的加法运算加1。

例如:

X=-101011 , [X]原= 1010_1011 ,[X]反=1101_0100,[X]补=1101_0101

负数的补码这么记更简单:符号位不变,其他的从低位开始,直到遇见第一个1之前,什么都不变;遇见第一个1后保留这个1,以后按位取反。

例:

[-7]原= 1 000011_1

[-7]补= 1 111100_1

PS:0的补码是唯一的,如果机器字长为8那么[0]补=0000_0000。

计算机源码,反码,补码之间怎么计算?

转换方法:

 如果是正数或零,则首位为 0,补码=原码=反码。

 否则,首位为 1,数值位取反加一,即可实现“补码与原码”互换。

例如:

 对 1111 1001 取反,为 1000 0110,再加一,得:1000 0111。

 对 1000 0111 取反,为 1111 1000,再加一,得:1111 1001。

这说明,补码 ←→ 原码,方法是相同的。

什么是源码,反码,补码?

这三个都是二进制数,如果源码是正的,那么反码,补码都是和源码是一样的,如果源码是负的话,其中最高位是符号位,1表示负,0表示正。比如-15,它的源码是10001111,反码就是把源码的0和1互换位置,其中符号位不变。-15的反码是11110000,补码就是在反码的基础上末尾加1就行了

源码 反码 补码的概念?

带符号数,有三种表示方法,即:原码、反码和补码。

但是,在计算机系统中,数值一律用【补码】来表示和存储。

所以,在计算机系统中,原码和反码,都是不存在的。

使用补码的意义:可以把减法或负数,转换为加法运算。

因此,就能简化计算机的硬件。

=====================

补码的概念,来自于:补数。

比如钟表,时针转一圈,周期是 12 小时。

那么,倒拨 3 小时,可以用正拨 9 小时代替。

9,就是-3 的补数。 计算方法: 9 = 12-3。

同理,分针倒拨 X 分,可以用正拨(60-X) 代替。

60,是分针的周期。

同理,三角函数的周期是 2π。 那么,

在-π/2 处 的函数值,就与 2π-π/2 = +3π/2 处 相同。

------------

当你使用两位十进制数:0~99,周期就是 一百。

那么,减一,就可以用 +99 代替。

24-1 = 23

24 + 99 = (1) 23

舍弃进位,这两种算法,功能就是相同的。

于是,99 就是 -1 的补数。

其它负数的补数,可以按照下式来求:

补数 = 周期 + 负数

------------

计算机中使用二进制,补数,就改称为【补码】。

八位二进制是:0000 0000~1111 1111。

相当于十进制:0~255, 周期就是 256。

那么,-1,就可以用 255 = 1111 1111 代替。

所以:-1 的补码,就是 1111 1111 = 255。

同理:-2 的补码,就是 1111 1110 = 254。

继续:-3 的补码,就是 1111 1101 = 253。

。。。

最后:-128 的补码,就是 1000 0000 = 128。

负数补码的计算公式:【 256 + 这个负数 】。

(式中的 256 = 2^8,是八位二进制的周期。)

正数,并不存在补码的问题。

所以,正数,并没有补码,可以直接运算。

(也有人乱说:正数本身就是补码。)

------------

求解算式: 7-3 = 4。

计算机中,并没有减法器,必须改用补码相加。

列竖式如下:

7 的补码=0000 0111

 -3的补码=1111 1101

--相加-------------

 得:(1)  0000 0100 = 4 的补码

舍弃进位,只保留八位,结果完全正确。

------------

借助于补码,可以简化计算机的硬件。

原码和反码,都没有这种功能。

所以,在计算机中,根本就没有原码和反码。

它们都是什么? 就不用关心了。

原码1的反码是多少?

对于任何的正数,原码反码和补码是完全相同的。所以,原码1的八位反码是00000001

5条大神的评论

  • avatar
    访客 2022-07-04 下午 09:21:55

    数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1.比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011

  • avatar
    访客 2022-07-04 下午 04:02:44

    ]补=0000_0000。计算机源码,反码,补码之间怎么计算?转换方法: 如果是正数或零,则首位为 0,补码=原码=反码。 否则,首位为 1,数值位取反加一,即可实现“补码与原码”互换。例如:

  • avatar
    访客 2022-07-04 下午 11:53:19

    果机器字长为n,那么一个数的原码就是用一个n位的二进制数,其中最高位为符号位:正数为0,负数为1。剩下的n-1位表示该数的绝对值。例如:X=+101011 , [X]

  • avatar
    访客 2022-07-05 上午 12:09:55

    。例如:X=-101011 , [X]原= 1010_1011 ,[X]反=1101_0100,[X]补=1101_0101负数的补码这么记更简单:符号位不变,其他的从低位开始,直到遇见第一个1

  • avatar
    访客 2022-07-04 下午 10:11:56

    1111 1110 = 254。继续:-3 的补码,就是 1111 1101 = 253。。。。最后:-128 的补码,就是 1000 0000 = 128。负数补码的计算公式:【

发表评论