数据结构-数字编码

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

基础知识

定义

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

作用

  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 数字编码

相关推荐
_GR15 分钟前
每日OJ题_牛客_牛牛冲钻五_模拟_C++_Java
java·数据结构·c++·算法·动态规划
ROBIN__dyc27 分钟前
表达式
算法
无限大.31 分钟前
c语言实例
c语言·数据结构·算法
六点半88835 分钟前
【C++】速通涉及 “vector” 的经典OJ编程题
开发语言·c++·算法·青少年编程·推荐算法
@haihi43 分钟前
冒泡排序,插入排序,快速排序,选择排序
数据结构·算法·排序算法
quaer1 小时前
Open-Sora全面开源?
开发语言·算法·机器学习·matlab·矩阵
Hello.Reader1 小时前
TopK算法在大数据重复数据分析中的应用与挑战
大数据·算法·数据分析
coduck_S12004zbj1 小时前
csp-j模拟五补题报告
c++·算法·图论
丢掉幻想准备斗争1 小时前
数据结构(栈和队列的实现)
数据结构
洛临_1 小时前
【C语言】基础篇
c语言·算法