奇偶校验

题目描述

输入一个字符串,然后对每个字符进行奇校验,最后输出校验后的二进制数(如'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() 返回是否有1
foo.none() 返回是否没有1
foo.set() 全都变成1
foo.set(p) 将第p + 1位变成1
foo.set(p, x) 将第p + 1位变成x
foo.reset() 全都变成0
foo.reset(p) 将第p + 1位变成0
foo.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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值