数据结构-数字编码

数字编码作为数据结构的一种重要形式,被广泛应用于各个领域,包括通信、图像处理、压缩算法等。本文将深入探讨数字编码的原理、常见的编码方法以及它们的应用。

基础知识

定义

数字编码是一种将数字数据转换为二进制形式的方法,以便计算机能够处理、存储和传输。它在计算机科学和信息技术领域起着重要作用,为数据的表示、压缩、加密以及通信提供了基础。

作用

  1. 数据表示:计算机中的所有数据都以二进制形式表示。通过数字编码,我们可以将各种类型的数据(如整数、浮点数、字符、图像、音频、视频等)转换为二进制形式,使计算机能够理解和处理这些数据
  2. 数据压缩:数字编码可以通过压缩算法将数据表示为更紧凑的形式,以减少存储空间或传输带宽的占用。

二进制表示法

二进制表示法是一种数字编码方法,使用只包含两个数字 0 和 1 的二进制位(bit)来表示数值。它是计算机中最基本、最常用的数字编码方式,也是所有其他数字编码的基础。

在二进制表示法中,每个位置上的数字称为位(bit),位的位置从右往左依次增加,每个位上的数字可以是 0 或 1。每个位所代表的数值是二的幂,从右往左依次递增。

常见的数字编码方法

整数编码

将整数转换为二进制的方法

原码

最简单的整数编码方法,直接将整数的二进制表示作为编码

将数字的二进制表示的最高位视为符号位,其中 0 表示正数,1 表示负数,其余位表示数字的值

反码

正数的反码与其原码相同,负数的反码是对其原码除符号位外的所有位取反

补码

正数的补码与其原码相同,负数的补码是在其反码的基础上加 1

反码作用

  1. 表示负数:在原码表示中,使用最高位(符号位)来表示正负,0 表示正数,1 表示负数。而使用反码表示负数时,只需要将正数的各个位取反(0 变为 1,1 变为 0),而符号位保持不变。
  2. 简化运算:使用反码表示负数可以简化负数的运算。在进行反码运算时,正数和负数的运算可以按照无符号数的运算方式进行,无需特殊处理符号位。负数的运算可以转化为正数的运算,减法可以转化为加法。

举例:1+(-2)可通过反码计算

补码作用

补码在计算机中用于表示有符号整数,其作用是简化负数的表示和运算,同时解决了反码表示的零值问题。

+0和-0表示如下:

在负零的反码基础上加 1 会产生进位,但 byte 类型的长度只有 8 位,因此溢出到第 9 位的 1 会被舍弃。也就是说,负零的补码为 00000000 ,与正零的补码相同。这意味着在补码表示中只存在一个零,正负零歧义从而得到解决。

浮点数编码

前期写过为啥浮点数不准确的文档,具体可查看:float为啥不准确

float 的表示方式包含指数位,导致其取值范围远大于 int 。根据以上计算,float 可表示的最大正数为 2^(254−127)×(2−2^(−23))≈3.4×10^38 ,切换符号位便可得到最小负数。

尽管浮点数 float 扩展了取值范围,但其副作用是牺牲了精度double也是类似

参考

1.3.3 数字编码

相关推荐
VertexGeek3 分钟前
Rust学习(八):异常处理和宏编程:
学习·算法·rust
石小石Orz4 分钟前
Three.js + AI:AI 算法生成 3D 萤火虫飞舞效果~
javascript·人工智能·算法
长风清留扬1 小时前
一篇文章了解何为 “大数据治理“ 理论与实践
大数据·数据库·面试·数据治理
jiao_mrswang1 小时前
leetcode-18-四数之和
算法·leetcode·职场和发展
qystca1 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱1 小时前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子1 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab
是阿建吖!1 小时前
【优选算法】二分查找
c++·算法
王燕龙(大卫)1 小时前
leetcode 数组中第k个最大元素
算法·leetcode
不去幼儿园2 小时前
【MARL】深入理解多智能体近端策略优化(MAPPO)算法与调参
人工智能·python·算法·机器学习·强化学习