题目描述
输入一个字符串,然后对每个字符进行奇校验,最后输出校验后的二进制数(如'3’,输出:10110011)。
输入描述:
输入包括一个字符串,字符串长度不超过100。
输出描述:
可能有多组测试数据,对于每组数据, 对于字符串中的每一个字符,输出按题目进行奇偶校验后的数,每个字符校验的结果占一行。
示例1
输入
3 3a
输出
10110011 10110011 01100001
这个题主要是学习了bitset。
bitset包含在头文件<bitset>中,命名空间为std。
一般构造为 bitset<n>bs()
n为二进制的位数,括号里的构造函数参数可以是整形,字符型和字符串。
同样也可以用=赋值(对于整形和字符型可以,字符串不行)
同时重载了[],不过[0]指的是最低位,[n-1]指的是最高位,与平常数组的高低位习惯相反。
一些常用的方法有
对于一个叫做foo的bitset:foo.size()
返回大小(位数)foo.count()
返回1的个数foo.any()
返回是否有1foo.none()
返回是否没有1foo.set()
全都变成1foo.set(p)
将第p + 1位变成1foo.set(p, x)
将第p + 1位变成xfoo.reset()
全都变成0foo.reset(p)
将第p + 1位变成0foo.flip()
全都取反foo.flip(p)
将第p + 1位取反foo.to_ulong()
返回它转换为unsigned long的结果,如果超出范围则报错foo.to_ullong()
返回它转换为unsigned long long的结果,如果超出范围则报错
foo.to_string()
返回它转换为string的结果
对于bitset的其他用法可参考:
https://blog.csdn.net/lanchunhui/article/details/49644373
此题代码:
#include <iostream>
#include <string>
#include <bitset>
using namespace std;
int main()
{
string a;
int i;
while(cin>>a)
{
for(i=0;i<a.size();i++)
{
bitset<8>bs(a[i]);
if(bs.count()%2 == 0)
bs[7] = 1;
cout<<bs.to_string()<<endl;
}
}
/*
char a= '3';
int b = 3;
string c = "00110011";
bitset<8> bs(c);
cout<<bs.to_string()<<endl;
cout<<bs.size()<<endl;
cout<<bs.count()<<endl;
*/
return 0;
}