题目描述
输入一个字符串,然后对每个字符进行奇校验,最后输出校验后的二进制数(如’3’,输出:10110011)。
输入描述:
输入包括一个字符串,字符串长度不超过100。输出描述:
可能有多组测试数据,对于每组数据,
对于字符串中的每一个字符,输出按题目进行奇偶校验后的数,每个字符校验的结果占一行。输入例子:
3
3a输出例子:
10110011
10110011
01100001
题目本意不难,理解奇偶检验有点费事
#include <iostream>
#include <bitset>
using namespace std;
/*思想就是:转为2进制后1的个数为偶数最高位要补1,注意ascii码最大就是127*/
int main()
{
char c;
int i;
bitset<8> bit;
while(cin>>c)
{
if(c == ' ' || c == '\n')
continue;
bit = c;
if((bit.count() & 1) == 0)//如果是奇数
bit.set(7);
cout<<bit<<endl;
}
return 0;
}