原码,反码,补码

原码,反码,补码

正数 : 原码 == 反码 == 补码

负数:

负数的反码 = 最高位符号位不变 + 其他位取反

取反就是 (1-bi)

一个k位的数,,如果要取反,,,k位全1,,也就是2的k次方-1,,然后再去减去原来的数,就是取反的数,,,

负数的反码,最高位是符号位,也就是最高位是不计算的,,,假设一个4位的数,k表示位数,k为4

他的原码 =

他的反码 =

2的k次方是一轮,,因为第一个数是符号位,,2的k-1次方是1轮,减去1,,,得到全1,,,全1减去原码 ==反码

另一种推导:


补码

计算机中用来表示有符号整数的一种编码方式,,核心作用是让加法和减法可以用同一套加法电路来计算,简化硬件设计

计算机里面实际存储的都是补码

模运算: 求余数的运算,数学上记作mod,日常也叫取模,,,

在模为256的系统中,,任何数加减256,结果都和原来等价

同余: 两个数除以同一个模,得到的余数相同,,就说这两个数是同余

同余正数:一个数在某个模下,最小正的同余数,,,模运算之后,把0换成模数本身,得到的那个最小正余数

补码的本质: 在这个对应的模下的同余正数

补码 = 反码 +1

反码是全1去减去 原码 ,, 全1,不是一轮,,,全1 加上 1 ,,才是一轮,,也就是补码

名字:

  • 函数: 每一个输入x,必须有唯一确定的一个输出y
    • 定义域 :输入的值
    • 陪域 : 目标,,输出允许落在哪个大范围
    • 值域 : 真正算出来的一对结果
  • 单射 : 两个不同的输入 x1,x2,对应的输出y1,y2也一定是不同的
  • 满射 : 函数输出集合里,每一个元素,都至少被一个输入对应到了,没有被漏掉的输出,,就是你算出来的结果必须把整个大范围的陪域全部填满,用光,一个不剩,,只要陪域里面有一个没算出来,就不叫满射
  • 双射: 既是单射,又是满射,,, 也就是一一对应,没有浪费,也没有冲突,,,双射一定有反函数,每个输出都能找到一个唯一的输入

在固定n位的情况下,,补码和数之间的转换是一个双射

相关推荐
小宇子2B1 天前
多线程 malloc 为什么会变慢——glibc 的 arena 到 bins 全景
操作系统
fakerth6 天前
【OpenHarmony】communication_ipc模块
操作系统·openharmony
Coisinier6 天前
RHCE中shell脚本基础(磁盘剩余空间监控,Web 服务状态检查,curl 访问 Web 服务并返回状态)
linux·运维·服务器·前端·nginx·操作系统
小宇子2B7 天前
free 完再 malloc 同样大小,为什么常拿回刚还回去的那块?
操作系统
触底反弹9 天前
拷个 .exe 到新电脑就跑不起来?你缺的不是文件,是对链接的理解
c++·windows·操作系统
杊页9 天前
第一板块:Android 系统基石与运行原理 | 第二篇:Android 编译、打包与安装机制
android·操作系统
壮Sir不壮9 天前
GO语言——GMP调度模型
linux·开发语言·golang·go·操作系统·线程·协程
Surest9 天前
OpenHarmony 技术拆解(二):从 capability 看懂分布式软总线与任务迁移
操作系统
OpenAnolis小助手10 天前
如何利用 AI Agent 实现热补丁的自动化生成
人工智能·安全·ai·操作系统·agent·龙蜥
小宇子2B11 天前
缺页中断不是“出错”,是内核最忙的一条正常路径
操作系统