数据结构-数字编码

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

基础知识

定义

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

作用

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

相关推荐
liujing10232929几秒前
Day05_数据结构(二叉树&快速排序&插入排序&二分查找)
数据结构
YuTaoShao4 分钟前
Java八股文——数据结构「排序算法篇」
java·数据结构·算法·面试·排序算法·八股文
电院工程师1 小时前
SM3算法C语言实现(无第三方库,带测试)
c语言·算法·安全·密码学
Hello.Reader2 小时前
RediSearch 查询语法速览
前端·算法
generallizhong3 小时前
android 省市区联动选择
android·java·算法
YGGP5 小时前
LeetCode 662. 二叉树的最大宽度
算法
周圣贤6 小时前
九尾狐编程语言新算法“超维时空演算体”
开发语言·算法
随缘而动,随遇而安8 小时前
第八十二篇 大数据开发基础:树形数据结构深度解析与实战指南(附创新生活案例)
大数据·开发语言·数据结构
药9559 小时前
数据结构 4 (栈和队列)
java·开发语言·数据结构
军训猫猫头10 小时前
100.Complex[]同时储存实数和虚数两组double的数组 C#例子
算法·c#·信号处理