1197_奇偶校验

本文介绍了一种通过C++实现的奇偶校验算法,该算法能够接收字符串输入,并针对每个字符完成奇校验过程,输出对应的二进制数值。通过对字符ASCII码的二进制形式进行分析,确定是否需要添加额外的校验位来确保输出中1的数量为奇数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目1197:奇偶校验

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:2132

解决:833

题目描述:

输入一个字符串,然后对每个字符进行奇校验,最后输出校验后的二进制数(如'3’,输出:10110011)。

输入:

输入包括一个字符串,字符串长度不超过100。

输出:

可能有多组测试数据,对于每组数据,
对于字符串中的每一个字符,输出按题目进行奇偶校验后的数,每个字符校验的结果占一行。

样例输入:
3
3a
样例输出:
10110011
10110011
01100001
********************************************************************
#include<iostream>
#include<string>
using namespace std;
int main()
{
	string s;
	int count;
	int n;
	int bit[7];//ascii只有7位
	int j;
	while(cin>>s)
	{
		for(int i=0;i!=s.size();i++)
		{  
			   count=j=0;
			   n=s[i];
			   while(n!=0)//将一个整型数转换成二进制数
			   {   
				   bit[j]=n%2;
				   if(bit[j]==1)//计算有多少个 1;
					   count+=1;
				   n=n/2;
				   j+=1;
				}
				while(j!=7)//共7位,空出的高位补0
				{
					bit[j]=0;
					j+=1;
				}
			if(count%2==0)//偶数个 1 
			{
				cout<<"1";
				for(int j=0;j!=7;j++)
					cout<<bit[6-j];
				cout<<endl;
			}
			else//奇数个 1
			{
				cout<<"0";
				for(int j=0;j!=7;j++)
					cout<<bit[6-j];
				cout<<endl;
			}
		}
	}
	return 0;
}









UART(Universal Asynchronous Receiver/Transmitter)是一种广泛用于串行通信的数据传输协议。它允许设备在没有专用同步信号的情况下通过单根数据线进行双向通信。UART传输的数据通常是以字符为单位,每个字符由起始位、数据位、奇偶校验位以及停止位组成。 在UART通信中,奇偶校验是一种简单的错误检测机制,用于提高数据传输的可靠性。其工作原理如下: 1. **计算校验位**:当发送方准备发送一串数据时,会在该串数据的最后加上一个校验位(奇偶位)。这个校验位根据特定规则来确定,目的是使得整个数据包中“1”的个数满足某种规律——通常是奇数或偶数。例如,在奇偶校验模式下,如果设置为“奇”,则整个数据序列中的“1”位数量将尽可能保持为奇数;如果是“偶”,则尽可能保持为偶数。 2. **附加到数据流**:发送方在数据的最后一个比特之后添加了此校验位,并以标准停止位结束数据流。 3. **接收和验证**:在接收端,接收方同样会检查接收到的数据中的“1”位总数是否符合预先设定的奇偶条件。如果数据传输过程中有任何错误导致最终的“1”位总数不符合预期的奇偶条件,接收方可以立即发现这一错误,并据此判断数据传输可能存在错误。 4. **错误处理**:一旦接收到的数据的奇偶校验失败,接收方可能会丢弃该数据包、请求重传、或是采取其他措施来响应错误状态。 通过这种方式,UART能够对数据流进行基本的错误检测,这对于许多低带宽、高可靠性的通信场景尤其有用。然而需要注意的是,尽管奇偶校验能提供一定的错误检测能力,但它无法识别所有型的错误,特别是对于突发误码或多比特错误的情况效果有限。因此,在要求极高可靠性的通信环境中,常常需要结合更复杂的错误纠正编码技术(如CRC循环冗余检验等)来增强系统的整体鲁棒性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值