【软考】3 校验码

news/2025/5/16 3:02:49/文章来源:https://www.cnblogs.com/mindzone/p/18447148

校验码

码距概念:任意进制的两个码值之间的最小二进制位数称为校验码的码距

例如:二进制1bit位,从0到1,则码距是1,二进制2bit位 从 00 到 11 一共4个码字,但码距还是为1

可以设置 性别男为 00 女为 11两个合法码字,则该两个合法码字的最小码距为2 (间隔 01 和 10 两个)

考点1: 奇偶校验码

奇偶校验码的编码方法是:由若干位有效信息(如一 个字节) ,再加上一个二进制位(校验位)组成校验码。
奇校验:整个校验码(有效信息位和校验位)中“1” 的个数为奇数。
偶校验:整个校验码(有效信息位和校验位)中“1” 的个数为偶数。

检查1位(奇数位)的错误,不可纠正错误

考点2: CRC循环冗余校验码

CRC的编码方法是:在 K 位信息码之后拼接 R 位校验码。只能检测错误,不可纠错
应用CRC码的关键是如何从k位信息位简便地得到r位校验位(编码) ,以及如何从 K + R 位信息码判断是否出错。

1、把接收到的CRC码用约定的生成多项式G(X)去除(模二除法),
2、如果正确,则余数为0;如果某一位出错, 则余数不为0。
3、不同的位数出错其余数不同,余数和出错位序号之间有唯一的对应关系。

考点3: 海明校验码

海明校验码的原理是:
在有效信息位中加入几个校验位形成海明码,使码距比较均匀地拉大,并把海明码的每个二进制位分配到几个奇偶校验组中。
当某一位出错后,就会引起有关的几个校验位的值发生变化,这不但可以发现错误,还能指出错误的位置,为自动纠错提供了依据

 

校验位求取公式:

推导公式1 2R >= M + R + 1

推导公式2 2R - 1 >= M + R

其中R为校验位值,M为信息位的个数

 

三种校验码的特性区分

 

例题:

例题一、以下关于海明码的叙述中,正确的是( )。
A、海明码利用奇偶性进行检错和纠错
B、海明码的码距为1
C、海明码可以检错但不能纠错
D、海明码中数据位的长度与校验位的长度必须相同

解题思路:

C选项,海明码可以检错也可以纠错,所以排除

D选项,数据位 M = 16时,校验位 R >= 5 所以不是必须相同,排除

B选项,校验码一定是通过扩大码距实现校验的,而海明码的码距必然大于1,排除

A选项,海明码使用分组奇偶校验实现,所以正确

 

例题二、海明码是一种纠错码,其方法是为需要校验的数据位增加若干校验位,使得校验位的值决定于某些被校位的数据,
当被校数据出错时, 可根据校验位的值的变化找到出错位,从而纠正错误。对于32位的数据,至少需要增加( ) _个校验位才能构成海明码。
以10位数据为例,其海明码表示【D9D8D7D6D5D4D3D2D1P3D0P2P1】中, 其中Di (0 ≤ i ≤ 9) 表示数据位,Pj (1 ≤ j ≤ 4)表示校验位,
数据位D9由P4P3和P2进行校验(从右至左D9的位序为14,即等于8+4+2,因此用第8位的P4、第4位的P3和第2位的P2校验) ,数据位D5由( )进行校验。

解题思路:

选项1:M = 32, 2^R - R >= 31,得到R >= 6 (R为5时 = 32,所以需要再 + 1),所以需要6个校验位

选项2:同理得知 D5的位序是10,位序16是 8 + 4 + 2,位序10是 8 + 2,所以由P4 + P2 校验

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/808369.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IOU指标

IOU:全称 intersection over union 交并比,两个区域真实框和预测框之间的交集比他们之间的总面积-交集的 IOU指标:通常用于评估计算机视觉任务中的模型性能,特别是目标检测和图像分割。一个较高的IoU值意味着模型的定位和分割精度更好。

Redis安装管理, RDB, AOF ubuntu使用

1.1 Redis 基础redis单线程处理用户请求,不用加锁。其他线程做别的工作1.2 Redis 安装 Ubuntu 安装 Redis 范例:基于官方仓库包安装 (可以安装最新版本)#官方地址 https://redis.io/docs/install/install-redis/install-redis-on-linux/#导入key [root@ubuntu2204 ~]#curl -f…

查找和管理数据库的具体步骤

登录MySQL命令行使用SSH连接到服务器。 登录MySQL命令行:bashmysql -u root -p输入MySQL root用户的密码。查看数据库列表在MySQL命令行中查看所有数据库:sqlSHOW DATABASES;选择织梦CMS数据库选择织梦CMS使用的数据库:sqlUSE dedecmsv56gbk;查看数据库表查看织梦CMS数据库中…

DedeCMS Error Track:DedeCMS错误警告:连接数据库失败

当织梦CMS(DedeCMS)出现“连接数据库失败”的错误时,可以通过以下几个步骤进行排查和解决: 1. 检查数据库配置文件打开配置文件打开织梦CMS的数据库配置文件 include/config.inc.php。 使用FTP工具或SSH连接到服务器,然后打开该文件。检查配置信息确认数据库配置信息是否正…

Redis安装管理, RDB完全快照 ubuntu使用

1.1 Redis 基础redis单线程处理用户请求,不用加锁。其他线程做别的工作1.2 Redis 安装 Ubuntu 安装 Redis 范例:基于官方仓库包安装 (可以安装最新版本)#官方地址 https://redis.io/docs/install/install-redis/install-redis-on-linux/#导入key [root@ubuntu2204 ~]#curl -f…

SpringMVC内容

SpringMVC简介 SpringMVC(Model View Controller) 是以Servlet API为基础的 Web 框架并可以部署到 Servlet容器(比如:Tomcat),是控制层框架,主要负责与前端交互,接收前端的参数,在服务层进行交互,并把结果返回会前端页面。 SpringMVC工作原理当发送请求的时候,Dis…

分层图

分层图 前言 在一次模拟赛中,我遇到了 [USACO15JAN] Grass Cownoisseur G 这道题,当时不知如何下手,和边上的同学偷偷讨论,听别人说是分层图,建两份图然后连一层反向边即可,当时对这个图论建模大为惊叹(不亚于我在学网络流时学到拆点拆边),故专门写一篇博客记录之。 算…

Github项目列表临时存放待整理

中台Admin前后端分离的权限管理系统 AutoUpdater.NET 是一个类库,允许 .NET 开发人员轻松地将自动更新功能添加到其经典桌面应用程序项目中。该库仅适用于 WinForms 或 WPF 应用程序项目。