余三码和8421码的关系以及使用场景

简介: 余三码与8421码是两种不同的二进制编码方式,常用于表示十进制数。余三码是8421码加上3形成的无权码,具有自补性和进位信号特点,适合错误检测,但求和需修正。8421码是恒权码,方便二进制与十进制转换,常用于数字显示、数据传输和精确十进制运算。在计算机领域,两者各有应用场景,如BCD码用于七段显示器和精确计算,余三码则用于错误检测和简化算术操作逻辑设计。


简单介绍以及二者的关系和区别


余三码和8421码是两种不同的二进制编码方式,用于表示十进制数。以下是它们之间的区别以及详细的介绍和例子:

余三码(余3码)

定义

余三码是由8421BCD码加上0011形成的一种无权码。由于它的每个字符编码比相应的8421码多3,故称为余三码。

特点

  1. 自补性:余三码具有9的自补代码特性,即十进制0和9、1和8、2和7、3和6、4和5对应的余三码互为反码。
  2. 进位信号:当两个十进制数的和是9时,相应的余三码的和正好是15,于是可自动产生进位信号,而不需修正。
  3. 修正方法:在将两个余三码表示的十进制数相加时,能正确产生进位信号,但对“和”必须修正。修正的方法是:如果有进位,则结果加3;如果无进位,则结果减3。

例子

以十进制数1318为例,其8421BCD码为0001 0011 0001 1000,转换为余三码后为0100 0110 0100 1011

8421码

定义

8421码是最常用的BCD码,也是十进制代码中最常用的一种。在这种编码方式中,每一位二值代码的“1”都代表一个固定数值。将每位“1”所代表的二进制数加起来就可以得到它所代表的十进制数字。

特点

  1. 恒权性:8421码是恒权码,因为代码中从左至右看每一位“1”分别代表数字“8”“4”“2”“1”,其权是固定不变的。
  2. 精确性:采用8421码既可保存数值的精确度,又可免却使电脑作浮点运算时所耗费的时间。
  3. 简便性:使二进制和十进制的转换变得方便。

例子

以十进制数1318为例,其8421BCD码直接为0001 0011 0001 1000


下表显示了0到9的十进制数对应的8421码和余三码:

Decimal 8421 Code Excess-3 Code
0 0000 0011
1 0001 0100
2 0010 0101
3 0011 0110
4 0100 0111
5 0101 1000
6 0110 1001
7 0111 1010
8 1000 1011
9 1001 1100

如您所见,8421码是直接的二进制表示,而余三码则是对每个十进制数字加上3的结果。这在某些计算和逻辑电路设计中可以提供错误检测等额外的好处。


总结

余三码和8421码的主要区别在于它们的编码方式和特性。余三码是一种特殊的无权码,具有自补性和自动进位信号的特点,但求和时需要修正;而8421码是恒权码,权值固定,使二进制和十进制的转换变得方便,且能保存数值的精确度。在应用中,根据具体需求选择合适的编码方式。




在计算机领域的使用



在计算机科学和电子工程领域,8421码(BCD码)和余三码(Excess-3码)有其特定的应用场景。下面我会具体说明这两种编码的常见用途:

8421码 (BCD码)

  1. 数字显示: 在需要显示十进制数字的设备中,如计算器、时钟、计数器和各种仪表盘,BCD码非常有用。这是因为BCD码可以直接驱动七段显示器,而无需进行复杂的二进制到十进制的转换。
  2. 数据传输: 在数据传输过程中,BCD码有时用于确保数据的准确性和简化校验过程。例如,在某些通信协议中,使用BCD码可以避免二进制到十进制转换中的错误。
  3. 算术运算: 虽然现代计算机内部通常使用二进制进行算术运算,但在一些嵌入式系统或特定应用中,BCD码被用来执行精确的十进制运算,这在金融和会计软件中尤为重要,以避免二进制浮点运算中的舍入误差。

余三码 (Excess-3码)

  1. 错误检测: 余三码的一个主要优点在于它可以用于简单的错误检测。由于每个BCD码都被加上了3,因此如果发生了单比特错误,接收到的编码将不会对应任何有效的余三码,从而可以被检测出来。
  2. 算术操作: 在一些情况下,余三码可以简化加法和减法的逻辑设计。例如,通过使用余三码,可以通过简单的逻辑门实现循环进位或借位,这在设计特定类型的算术逻辑单元(ALU)时很有帮助。
  3. 编码转换: 在需要从BCD码转换到其他形式的编码,或反之亦然的情况下,余三码提供了一种中间步骤,可以简化编码之间的转换过程。

总的来说,尽管在大多数高性能计算任务中,纯二进制编码因其效率而占主导地位,但在需要处理十进制数据的精确性或在低功耗、低成本的嵌入式系统中,BCD码和余三码仍然有其不可替代的作用。




相关文章
|
算法 C++
Morton码的计算
Morton码是对栅格格网进行编码的一种算法,在Google中搜索Morton,搜索结果第一位是Wikipedia的Z-order Curve,这是因为Morton码编码结果展现为一种Z形的填充曲线。下面简要说一下如何计算四进制和十进制的Morton码。
560 0
|
存储
系统码的编译码与汉明码
系统码的编译码与汉明码
164 0
系统码的编译码与汉明码
|
PyTorch TensorFlow 算法框架/工具
福利:推荐你在线码代码
福利:推荐你在线码代码
112 0
|
存储 XML 设计模式
一个简单的Android网络访问全局码判断及通用数据解析方案
我们在开发中,网络请求经常会遇到各种错误码的判断。比如下面这样:
147 0
|
安全 Java 数据库
案例之授权码模式测试|学习笔记
快速学习案例之授权码模式测试
案例之授权码模式测试|学习笔记
TP5.1对登录的返回码优化
TP5.1对登录的返回码优化
147 0
TP5.1对登录的返回码优化
|
数据库
LeetCode(数据库)- 使用唯一标识码替换员工ID
LeetCode(数据库)- 使用唯一标识码替换员工ID
125 0
|
安全 UED
OAuth 2.0实战(二)-为什么要先获取授权码code?(上)
OAuth 2.0实战(二)-为什么要先获取授权码code?
316 0
OAuth 2.0实战(二)-为什么要先获取授权码code?(上)
|
小程序 开发工具 开发者
OAuth 2.0实战(二)-为什么要先获取授权码code?(下)
OAuth 2.0实战(二)-为什么要先获取授权码code?
317 0
OAuth 2.0实战(二)-为什么要先获取授权码code?(下)

热门文章

最新文章