原码,反码,补码

原码,反码,补码

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

负数:

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

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

相关推荐
暴力求解1 天前
Mysql数据库基础
数据库·mysql·操作系统
用户887665426631 天前
Linux 终端入门:新手必须掌握的常用命令和基本思路
前端·操作系统
atomicmaker3 天前
操作系统 — 内存管理
操作系统·内存管理·虚拟内存·段页式
atomicmaker3 天前
操作系统 — 文件管理
操作系统·文件管理·文件系统·计算机系统
白狐_7983 天前
【XV6操作系统】Lab2(Page Table) 满分通关与答辩指南:结合408考点深度剖析
操作系统·麒麟·xv6
atomicmaker4 天前
操作系统 — 设备管理
操作系统·磁盘·设备管理·缓冲
z200509304 天前
【Linux学习】Linux中进程终止和进程等待
linux·学习·操作系统
niannian4 天前
从零开始!RuyiSDK + RISC-V 新手完整入门指南(Windows WSL2 环境)
操作系统
Bruce_kaizy5 天前
c++ linux环境编程——文件io介绍以及open 、write 、read 三剑客深度详解
linux·服务器·c++·ubuntu·操作系统·文件io
morn_venus5 天前
从 20 倍性能差距看 Linux 的 vDSO 与 vvar 机制
操作系统