原码,反码,补码

原码,反码,补码

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

负数:

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

取反就是 (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位的情况下,,补码和数之间的转换是一个双射

相关推荐
-To be number.wan2 天前
操作系统核心机制:处理机调度与死锁全解析
学习·操作系统
-To be number.wan3 天前
操作系统 | 关于时间片大小的确定问题
学习·操作系统
请输入蚊子4 天前
《操作系统真象还原》 第十一章 用户进程
linux·操作系统·操作系统真像还原
菜鸟的日志4 天前
【嵌入系统】嵌入式学习笔记(一)
windows·笔记·嵌入式硬件·学习·ubuntu·操作系统
-To be number.wan5 天前
操作系统 | 进程调度机制全解析
学习·操作系统
Kapaseker6 天前
为什么 Windows 非要用 \ 当目录分隔符
操作系统
Zik----7 天前
操作系统核心考点(面试/期末复习)
面试·操作系统·研究生面试·期末复习专业课计算机
雪碧聊技术8 天前
上午题_操作系统
操作系统·软件设计师
星马梦缘8 天前
操作系统实验4 —— 计算机系统中的 IPC
操作系统·共享内存·os·管道·ipc
mifengxing9 天前
操作系统(四)
linux·服务器·网络·操作系统