整数补码加减法运算法则是什么_补码加减法中

整数补码加减法运算法则是什么_补码加减法中整数的补码计算正数的补码计算:与原码相同负数的补码计算:①先求出负数的原码,如-4的原码为10000100②通过原码求出反码,负数的反码就是:除符号位以外,其他位全部取反,如-4的反码为11111011③负数的补码等于负数的反码末位+1,如-4的补码为11111100特例:约定-128的补码为10000000注:若已知补码求原码:正数也是它本身,负数的求法同上,即对补码除符号位外取反,末位加1,就得到原码整数补码加减运算加法[A+B]补=[A]补+[B]补减法[

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

整数的补码计算

正数的补码计算:与原码相同
负数的补码计算:
①先求出负数的原码,如-4的原码为1000 0100
②通过原码求出反码,负数的反码就是:除符号位以外,其他位全部取反,如-4的反码为1111 1011
③负数的补码等于负数的反码末位+1,如-4的补码为1111 1100
特例:约定-128的补码为1000 0000

注:若已知补码 求原码:正数也是它本身,负数的求法同上,即对补码除符号位外取反,末位加1,就得到原码

整数补码加减运算

加法

[A+B]补 = [A]补 + [B]补

减法

[A-B]补 = [A]补 + [-B]补

注:[-B]补的求法是:[B]补 连同符号位在内,每位取反,末位加1

举例

(1) 已知A=4,B=-5,求A+B,A-B:

  • 4的补码:[A]补 = 0000 0100;
  • -5的原码:[B]原 = 1000 0101,-5的反码:[B]反 = 1111 1010,-5的补码: [B]补 = 1111 1011;
  • 已知-5的补码是1111 1011,连同符号位在内每位取反得到0000 0100,末位加1得到[-B]补 = 0000 0101;
  • A+B:[A+B]补 = [A]补 + [B]补 = 0000 0100 + 1111 1011 = 1111 1111,但1111 1111是补码形式,要得到原码,首先除符号位外取反得到1000 0000,末位加1得到1000 0001,对应的值为-1
  • A-B:[A-B]补 = [A]补 + [-B]补 = 0000 0100 + 0000 0101 = 0000 1001,可见是正数,补码即原码,对应的值为9

(2)已知A=-128, B=-127, C=127, 求B-A, C-A, C-B

  • -128的补码:[A]补 = 1000 0000,-127的补码: [B]补 = 1000 0001,127的补码:[C]补 = 0111 1111
  • -[A]补:[A]补 1000 0000 -> 全部取反 0111 1111 ->末位加一 1000 0000
  • -[B]补:[B]补 1000 0001 -> 全部取反 0111 1110 ->末位加一 0111 1111
  • B-A:[B-A]补 = [B]补 + [-A]补 = 1000 0001 + 1000 0000 = 0000 0001,可见是正数,对应的值为1
  • C-A:[C-A]补 = [C]补 + [-A]补 = 0111 1111 + 1000 0000 = 1111 1111,可见是负数,需要转换位对应的原码再求值,转为原码是1000 0001,对应的值为-1
  • C-B: [C-B]补 = [C]补 + [-B]补 = 0111 1111 + 0111 1111 = 1111 1110,可见是负数,需要转为对应原码再求值,转为原码是10000010,对应的值为-2
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190626.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言fread函数的功能_c语言sizeof函数用法

    c语言fread函数的功能_c语言sizeof函数用法C语言中:fread是一个函数。从一个文件流中读数据,最多读取count个元素,每个元素size字节,如果调用成功返回实际读取到的元素个数,如果不成功或读到文件末尾返回0。下面我们来看看c语言fread函数的用法。fread()函数—-Readsdatafromastream.#includesize_tfread(void*buffer,size_tsize,size…

    2025年11月7日
    6
  • jar包和war包区别及理解

    jar包和war包区别及理解在开发阶段不适合使用war包,因为在开发阶段,经常需要添加或删除Web应用程序的内容,更新Servlet类文件,而每一次改动后,重新建立war包将是一件浪费时间的事情。在产品发布阶段,使用war文件比较合适的,因为在这个时候,几乎不需要再做什么改动了。jar包jar是类的归档文件JAR(JavaArchive,Java归档文件)是与平台无关的文件格式,它允许将许多文件组合成一个压缩文件,为J2EE应用程序创建的jar文件是EAR文件(企业jar文件),jar文件格式以流行的ZIP文

    2022年5月24日
    35
  • OHEM 详解「建议收藏」

    OHEM 详解「建议收藏」(一)HardNegativeMiningMethod(二)OHEM

    2022年5月30日
    41
  • myPagination5.0 分页简单实例「建议收藏」

    myPagination5.0 分页简单实例

    2022年1月31日
    32
  • vue 的双向绑定原理「建议收藏」

    vue 的双向绑定原理「建议收藏」vue采用“数据劫持”和“观察者模式(又叫做发布者-订阅者模式)”相结合的方式,通过Object.defineProperty()来劫持各个属性的setter、getter,在数据变动时发布消息给订阅者,触发相应的监听回调。vue的双向绑定原理,分三步:第一步,“数据劫持”:vue用Object.defineProperty()方法实现数据劫持,为每个属性分配一个订阅者集合的管理数组dep; 第二步,“添加观察者”:在编译的时候在该属性的数组dep中添加订阅者,添加方式包括:v

    2022年8月31日
    5
  • mac安装mysql中设置密码遇到的问题和设置快捷命令打开mysql

    mac安装mysql中设置密码遇到的问题和设置快捷命令打开mysql

    2021年9月12日
    61

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号