原码反码补码

正数

正数的原码就是该数的二进制表现形式,正数的反码,补码与原码一致
如:56的原码:0011 1000
56的反码:0011 1000
56的补码:0011 1000
其中:0(符号位) 011 1000(数据),最高位为符号位,当符号位为0是正数,符号位为1是负数
最大值:0111 1111(+127)
最小值:1111 1111(-127)

负数

负数的原码转换形式:先将该负数的正数表现形式转换为二进制,将二进制的符号位变为1
如:-56转换为原码:
1,56的二进制表现形式:00111000
2,最高位变为1:10111000

负数的反码转换形式:负数的原码符号位不变,数值取反,0变为1,1变为0
如:10111000(十进制为56)转换为反码:11000111
负数的补码转换形式:将该负数的反码加1
如:11000111(56)转换为补码:11001000


补充:

1,负数的反码是为了解决原码不能计算负数的问题而出现的,负数的原码加1减1与产生的结果的原码不一致的问题
如:-1原码:1000 0001,-1减1=-2,但是原码1000 0001减1:1000 0000,结果为0
-1加1=0,但是原码1000 0001加1:1000 0010,结果为-2
利用反码,-1反码:1111 1110,-1减1=-2,反码1111 1110减1:1111 1101,转换为原码结果为-2
-1加1=0,反码1111 1110加1:1111 1111,转换为原码结果为0

2,负数的补码是为了解决正数与负数的计算跨0的问题。
负数的反码的0有两种表现形式,分别是:+0:0000 0000,-0:1111 1111,当负数的计算涉及到跨0时,就会有1的误差.比如:-5+7=2,跨0了,此时负数-5+7得到的反码是1
负数的补码是为了解决负数的计算涉及到跨0时,就会有1的误差这个问题。
负数的补码将补码错开一位,将-0反码(1111 1111)变为-1的补码,即负数的反码+1就会变成该负数的补码。如下图所示:
负数的原码反码补码图
负数的原码反码补码图
3,计算机中的存储和计算都是以补码的形式进行的

其他运算符
其他运算符
&:两边都为真结果才为真,只要有一个false结果就是false
|:两边都为false结果才为false,只要有一个true就是true
<<:左移一位相当于该数*2
》:右移一位相当于该数/2

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
原码反码补码计算口诀是: 1. 原码:符号位加上真值的绝对值。 2. 反码:将原码中的符号位保持不变,其余位取反。 3. 补码反码加1。 例如,对于一个8位二进制数,如果要计算其反码,可以按照以下步骤进行: 1. 将符号位保持不变。 2. 将其余位取反。 对于补码的计算,可以按照以下步骤进行: 1. 先计算其反码。 2. 在反码的基础上加1。 这样,就可以得到原码、反码补码的计算结果。 #### 引用[.reference_title] - *1* [原码, 反码, 补码的基础概念和计算方法](https://blog.csdn.net/Chinajsczlymyc/article/details/126910306)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [(转)java 原码反码补码计算 以及 取反运算,原码反码补码运算公式](https://blog.csdn.net/PacosonSWJTU/article/details/128604733)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [原码,补码,反码概念和计算方法详解](https://blog.csdn.net/qq_39541098/article/details/122729622)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值