为什么带上符号位计算,仍然可以算出正负数对应的补码

news2025/1/11 7:15:34

请添加图片描述

文章目录

  • 🚀前言
  • 🚀 为什么要引入原反补码
    • ✈️ 利用加法表示减法
    • ✈️ 关于数字在计算机中的存储
    • 🚀 数学解释
  • 🚀 为什么带上符号位计算,仍然可以算出正负数对应的补码

🚀前言

为应付期末,速成数电,看到原反补码,不知道为啥计算结果仍然为补码,查了半天决定记录。

🚀 为什么要引入原反补码

因为对于数的加减运算,加法很容易但是减法很麻烦(硬件上实现),所以大佬们利用加法表示减法。下面我们来看具体如何操作:

✈️ 利用加法表示减法

我们用一个🌰来解释:

用两个 仅一位十进制数 演示:7-3=7+(-3)
实际上,7+(-3) 等于 7+(10 - 3) = 14。虽然 7+(10-3) 的结果为 14,但由于只有一位,所以高位 1 舍去,结果为 4,与 7-3=4 一致。
将这个结论推广到更多位或其他进制依然适用,比如用三位表示 155-123=155+(-123)=32,同样的 155+(1000-123)=1032,高位去掉结果仍然正确。
在计算机中就是这么算的,上面的过程相当于模拟了计算机计算的过程,只不过计算机使用二进制计算,舍去高位叫 溢出

✈️ 关于数字在计算机中的存储

上面利用 加法表示减法 的过程中用到了 减法,我们引入原反补码来解决这个问题。

在计算机中,我们利用二进制进行数字存储和计算。比如上述的例子 7-3=7+(-3)=7+(10-3) 中,我们眼中的 7-3,而在计算机眼中没有减法只有加法,所以计算机看到的是 7+(-3)
如何区分正负数?规则:正数最高位为0,负数最高位为1。
以有符号 int 类型为例,正数的最高位为0,负数的最高位为1。

为了避免减法,引入了反码和补码:

  • 反码:符号位不变,其他位按位取反。
  • 补码:反码加1。

🚀 数学解释

补码运算的数学基础可以用以下公式来解释:

  1. 对于正数 ( a ) (a) (a)

    • 补码:直接等于原码。
  2. 对于负数 ( − b ) (-b) (b)

    • 补码:等于 ( 2 n − b ) (2^n - b) (2nb)

在补码运算中,加法和减法通过以下方式处理:

a + ( − b ) = a + ( 2 n − b ) = ( a − b + 2 n ) m o d    2 n a + (-b) = a + (2^n - b) = (a - b + 2^n) \mod 2^n a+(b)=a+(2nb)=(ab+2n)mod2n

由于超出 (n) 位的部分被丢弃,最终结果在正确范围内。

🚀 为什么带上符号位计算,仍然可以算出正负数对应的补码

上面铺垫了这么多就是为了介绍这个终极问题,下面为大家解惑:

实际上,有了上面的基础,很好理解为什么符号位参与计算仍对。分为三种情况:正数与正数,负数与负数,负数与正数。但正数与正数和负数与负数不能发生溢出,这种溢出不被允许,所以只考虑正数与负数。
正数绝对值更大时,会进位到符号位,符号位再次进位溢出,然后符号位为0,结果为正数;负数绝对值更大时,不会发生溢出,符号位最后为1,结果为负数。

举例:

表示数值位有三位: a + (-b)
a = 101
b = 011
补码(-b) = 1000 - 0011 = 101
a + (-b) = a + 补码(-b) = 101 + 101 = 1010,a > b溢出到符号位,符号位进位然后结果为正
a = 011
b = 101
补码(-b) = 1000 - 0105 = 011
a + (-b) = a + 补码(-b) = 011 + 011= 110,a < b 没有溢出,符号位为1结果为负


如果帮到你,请帮我点个赞吧!

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1839836.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

N7745A Keysight 是德 多端口光功率计 简述

N7745A光功率计专为表征多端口光器件而设计&#xff0c;适用于多路复用器、PON分路器、波长选择开关&#xff08;WSS&#xff09;和ROADM等多端口器件的测试。它可以节省通道空间&#xff0c;通过LAN或USB连接进行并行编程&#xff0c;集成多种设备到单一设置&#xff0c;提高了…

[Qt] Qt Creator中配置 Vs-Code 编码风格

新建vscode-onedark.xml文档 &#xff0c;将如下内容复制进去&#xff0c;并配置到Creator中&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <style-scheme version"1.0" name"One Dark"><style name"Tex…

打造一个属于你的桌面天气 超级有个性的天气桌面

打造一个属于你的桌面天气 超级有个性的天气桌面。大家好&#xff0c;今天我们带来一个非常有趣的桌面天气工具&#xff0c;喜欢桌面diy的你&#xff0c;快点用上它吧&#xff01; 桌面上的美化&#xff0c;是许多爱美用户的心血和热爱。每个地方的美化&#xff0c;都是自己亲…

信息论与大数据安全知识点

文章目录 第一章 绪论&#xfffc;大数据概述大数据安全与加密技术 安全存储与访问控制技术访问控制概念早期的四种访问控制模型局限性总结 大数据场景下的访问控制技术 安全检索技术密文检索基础 安全处理技术同态加密 隐私保护技术 第一章 绪论&#xfffc; 大数据概述 大数…

【QT5】<重点> QT多线程

文章目录 前言 一、QThread创建多线程 二、QMutex基于互斥量的同步 三、QReadWriteLock线程同步 四、QWaitCondition线程同步 五、QSemaphore基于信号量的同步 前言 本篇记录学习QT多线程的知识&#xff0c;参考视频13.1QThread创建多线程程序_哔哩哔哩。若涉及版权问题…

【C语言】C语言入门宝典:核心概念全解析

. C语言专栏 | C专栏 &#x1f449; 个人主页 &#x1f448; 前言 此篇文章我们主要是宏观的了解一下什么是C语言&#xff0c;C语言里面有那些知识点&#xff0c;所有的知识点我们此篇只是以入门为主&#xff0c;点到为止&#xff0c;简单易懂&#xff0c;后期的文章会一 一详…

苍穹外卖---编辑员工(P27-P29)

一、需求分析与设计 &#xff08;1&#xff09;产品原型 在员工管理列表页面点击 "编辑" 按钮&#xff0c;跳转到编辑页面&#xff0c;在编辑页面回显员工信息并进行修改&#xff0c;最后点击 "保存" 按钮完成编辑操作。 员工列表原型&#xff1a; 修改…

全网最全!25届最近5年华东理工大学自动化考研院校分析

华东理工大学 目录 一、学校学院专业简介 二、考试科目指定教材 三、近5年考研分数情况 四、近5年招生录取情况 五、最新一年分数段图表 六、历年真题PDF 七、初试大纲复试大纲 八、学费&奖学金&就业方向 一、学校学院专业简介 二、考试科目指定教材 1、考试…

Google 广告VS Facebook广告:哪个更适合我?2024全维度区别详解

在 Google Ads 和 Facebook Ads 之间进行选择可能是一个艰难的决定。决定哪种方法适合您的业务取决于多种因素&#xff0c;从您愿意为转化支付的费用到管理广告系列所需的时间和人员。在这篇文章中&#xff0c;将解释 Google Ads 和 Facebook Ads 之间的差异&#xff0c;以便您…

吴恩达机器学习作业ex3:多类分类和前馈神经网络(Python实现)详细注释

文章目录 1 多类分类1.1数据集1.2 数据可视化1.3 向量化逻辑回归1.3.1 向量化代价函数1.3.2 矢量化梯度下降以及正则化表达1.4 一对多分类 2.神经网络2.1模型表示 总结&#xff08;自己训练求解参数全流程&#xff09; 1 多类分类 在本练习中&#xff0c;您将使用逻辑回归和神…

element v-loading 加载组件增加按钮

2024.06.19今天我学习了如何对v-loading组件增加按钮&#xff0c;效果如下&#xff1a; 代码如下&#xff1a; <template><el-table v-loading"loading"><template v-slot:append><el-button v-if"loading" type"warning"…

龙芯LS2K0300久久派上手体验

介绍 芯片 龙芯2K0300芯片是一款基于LA264处理器核的多功能SoC芯片&#xff0c;可广泛适用于工业控制、通信设备、信息家电和物联网等领域&#xff1b;该芯片采用高集成度设计&#xff0c;可提供丰富的功能接口&#xff0c;满足多场景应用需求&#xff0c;同时支持低功耗技术…

springboot中,将某个函数的日志单独输出的方法

这里写自定义目录标题 背景解决方案解决过程原理 背景 项目中有个节点健康检查扫描功能&#xff0c;每10秒扫描一次节点。 如果节点挂掉&#xff0c;会输出健康检查失败的日志。 测试环境&#xff0c;虽然配置了多个节点&#xff0c;但并没有都启动&#xff0c;所以在扫描的时…

Python学习笔记14:进阶篇(三)。类的终结篇,类的导入和模块的导入。

前言 这篇文章属于类知识的最后一篇&#xff0c;带一点点其他知识&#xff0c;学习内容来自于Python crash course。 关注我私信发送Python crash course&#xff0c;分享一份中文版PDF。 类的导入 在学习的时候&#xff0c;包括之前&#xff0c;我都是在一个文件中把所有代…

matlab线性多部法求常微分方程数值解

用Adamas内差二步方法&#xff0c;内差三步方法&#xff0c;外差二步方法&#xff0c;外差三步方法这四种方法计算。 中k为1和2. k为2和3 代码 function chap1_adams_methodu0 1; T 2; h 0.1; N T/h; t 0:h:T; solu exact1(t);f f1; u_inter_2s adams_inter_2steps(…

【C++高阶】高效搜索的秘密:深入解析搜索二叉树

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ ⏩收录专栏⏪&#xff1a;C “ 登神长阶 ” &#x1f921;往期回顾&#x1f921;&#xff1a;C多态 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀二叉搜索树 &#x1f4d2;1. 二叉搜索树&…

项目训练营第二天

项目训练营第二天 用户登录逻辑 1、账户名不少于4位 2、密码不少于8位 3、数据库表中能够查询到账户、密码 4、密码查询时用同样加密脱敏处理手段处理后再和数据库中取出字段进行对比&#xff0c;如果账户名未查询到&#xff0c;直接返回null 5、后端设置相应的脱敏后用户的s…

如何使用alias永久别名(linux篇)

一、alias的使用 alias主要作用是起一个别名的用处 它又分两种形式&#xff1a; ① 临时别名 ② 永久别名 1.第一种&#xff08;临时别名&#xff09;&#xff1a; C:\Users\62452>ssh root192.168.0.102 root192.168.0.102s password: Last login: Sat Jun 15 16:30:12 20…

18张Python数据科学速查表.png

数据科学已经发展成为一个庞大的系统&#xff0c;包含数学、统计学、概率论、计算机、数据库、编程等各种理论技术。 目前在主流的数据科学领域一般有三大生态&#xff0c;一是以sas、matlab、spss等为代表的商业软件生态&#xff0c;二是围绕R语言建立起来的开源生态&#xf…

移动硬盘在苹果电脑上无法识别的诊断与恢复策略

一、问题描述 在数字时代&#xff0c;移动硬盘已成为我们存储和传输数据的重要工具。然而&#xff0c;当我们将移动硬盘插入苹果电脑时&#xff0c;有时会遇到无法识别的情况&#xff0c;这让我们感到十分困扰。本文将详细探讨移动硬盘插苹果电脑后读不出来的现象&#xff0c;…