C++语言基础 —— STL —— 容器与迭代器 —— bitset

【概述】

bitset 位于 <bitset> 头文件中,其是 STL 的一部分,准确地说,bitset 是一个模板类而不是容器,其模板参数不是类型,而整型的数值,即:bitset <N> 

bitset 存储的是二进制位,与一个 bool 型的数组相似,其每位只占一个字节,极大的优化了空间,使用 bitset 可以像使用数组一样利用位。

【定义】

bitset 的定义为在定义时必须定义其大小,定义一个空 bitset 时所有值默认为 0

bitset<8> bit1;
bitset<8> bit2(8);
bitset<8> bit3(string("01010101"));
bitset<8> bit4(bit2);

cout<<"bit1="<<bit1<<endl;//bit1=00000000
cout<<"bit2="<<bit2<<endl;//bit2=00001000
cout<<"bit3="<<bit3<<endl;//bit3=01010101
cout<<"bit4="<<bit4<<endl;//bit4=00001000

【运算】

bitset 可以直接做位运算

bitset<4> bit1(string("0101"));
bitset<4> bit2(string("1110"));

cout<<"(bit1&bit2)="<<(bit1&bit2)<<endl;//(bit1&bit2)=0100
cout<<"(bit1|bit2)="<<(bit1|bit2)<<endl;//(bit1|bit2)=1111
cout<<"(bit1^bit2)="<<(bit1^bit2)<<endl;//(bit1^bit2)=1011
cout<<"(~bit1)="<<(~bit1)<<endl;//(~bit1)=1010

cout<<"(bit1&=bit2)="<<(bit1&=bit2)<<endl;//(bit1&=bit2)=0100
cout<<"(bit1|=bit2)="<<(bit1|=bit2)<<endl;//(bit1|=bit2)=1110
cout<<"(bit1^=bit2)="<<(bit1^=bit2)<<endl;//(bit1^=bit2)=0000
cout<<"(bit1<<=1)="<<(bit1<<=1)<<endl;//(bit1<<=1)=0000
cout<<"(bit1^=4)="<<(bit1^=4)<<endl;//(bit1^=4)=0100

cout<<"(bit1==bit2)="<<(bit1==bit2)<<endl;//(bit1==bit2)=0
cout<<"(bit1!=bit2)="<<(bit1!=bit2)<<endl;//(bit1!=bit2)=1

【循环移位操作】

由于 bitset 没有循环移位,所以可将循环移位进行拆解,有:

  • 左移 k 位时:先左移 k 位,再右移 m-k 位,最后两者取或,即:(x<<k)|(x>>(m-k))
  • 右移 k 位时:先右移 k 位,再左移 m-k 位,最后两者取或,即:(x>>k)|(x<<(m-k))
bitset<N> left(bitset<N> &x,int val,int len) {//val为移动位数,len为bitset长度
    return (x<<val)|(x>>(len-val));
}
bitset<N> right(bitset<N> &x,int val,int len) {val为移动位数,len为bitset长度
    return (x>>val)|(x<<(len-val));
}

【函数】

bitset 没有迭代器,但其函数十分便捷

  • bit.size();//返回长度
  • bit.count();//返回1的个数
  • bit.any();//返回是否有1
  • bit.none();//返回是否没有1
  • bit.set();//全部置为1
  • bit.set(p);//下标从0开始,将p+1的位置为1
  • bit.set(p,n);//将p+1位置为n
  • bit.reset();//全部置为0
  • bit.reset(p);//将p+1位置为0
  • bit.flip();//全部取反等同于(~bit)
  • bit.flip(p);//将p+1位取反
  • bit.to_ulong();//返回转换为unsignedlong的结果,超范围会报错
  • bit.to_ullong();//返回转换为unsignedlonglong的结果,超范围报错
  • bit.to_string();//返回转换为string的结果
C++STL中实现由一个bitset类模板,其用法如下: std::bitset bs; 也就是说,这个bs只能支持64位以内的位存储和操作;bs一旦定义就不能动态增长了。本资源附件中实现了一个动态Bitset,和标准bitset兼容。 /** @defgroup Bitset Bitset位集类 * @{ */ //根据std::bitset改写,函数意义和std::bitset保持一致 class CORE_API Bitset: public Serializable { typedef typename uint32_t _Ty; static const int _Bitsperword = (CHAR_BIT * sizeof(_Ty)); _Ty * _Array; //最低位放在[0]位置,每位的默认值为0 int _Bits;//最大有效的Bit个数 private: int calculateWords()const; void tidy(_Ty _Wordval = 0); void trim(); _Ty getWord(size_t _Wpos)const; public: //默认构造 Bitset(); //传入最大的位数,每位默认是0 Bitset(int nBits); virtual ~Bitset(); //直接整数转化成二进制,赋值给Bitset,最高低放在[0]位置 Bitset(unsigned long long _Val); //拷贝构造函数 Bitset(const Bitset & b); Bitset(const char * str); Bitset(const std::string & str, size_t _Pos, size_t _Count); public: size_t size()const; //返回设置为1的位数 size_t count() const; bool subscript(size_t _Pos) const; bool get(size_t pos) const; //设置指定位置为0或1,true表示1,false表示0,如果pos大于数组长度,则自动扩展 void set(size_t _Pos, bool _Val = true); //将位数组转换成整数,最低位放在[0]位置 //例如数组中存放的1011,则返回13,而不是返回11 unsigned long long to_ullong() const; bool test(size_t _Pos) const; bool any() const; bool none() const; bool all() const; std::string to_string() const; public: //直接整数转化成二进制,赋值给Bitset,最高位放在[0]位置 Bitset& operator = (const Bitset& b); //直接整数转化成二进制,赋值给Bitset,最高位放在[0]位置 Bitset& operator = (unsigned long long ull); //返回指定位置的值,如果pos大于位数组长度,自动拓展 bool operator [] (const size_t pos); //测试两个Bitset是否相等 bool operator == (const Bitset & b); bool operator != (const Bitset & b); Bitset operator<>(size_t _Pos) const; bool operator > (const Bitset & c)const; bool operator < (const Bitset & c)const; Bitset& operator &=(const Bitset& _Right); Bitset& operator|=(const Bitset& _Right); Bitset& operator^=(const Bitset& _Right); Bitset& operator<>=(size_t _Pos); public: Bitset& flip(size_t _Pos); Bitset& flip(); //将高位与低位互相,如数组存放的是1011,则本函数执行后为1101 Bitset& reverse(); //返回左边n位,构成新的Bitset Bitset left(size_t n) const; //返回右边n位,构成新的Bitset Bitset right(size_t n) const; //判断b包含的位数组是否是本类的位数组的自串,如果是返回开始位置 size_t find (const Bitset & b) const; size_t find(unsigned long long & b) const; size_t find(const char * b) const; size_t find(const std::string & b) const; //判断本类的位数组是否是b的前缀 bool is_prefix(unsigned long long & b) const; bool is_prefix(const char * b) const; bool is_prefix(const std::string & b) const; bool is_prefix(const Bitset & b) const; void clear(); void resize(size_t newSize); void reset(const unsigned char * flags, size_t s); void reset(unsigned long long _Val); void reset(const char * _Str); void reset(const std::string & _Str, size_t _Pos, size_t _Count); //左移动n位,返回新的Bitset //extendBits=false "1101" 左移动2位 "0100"; //extendBits=true "1101" 左移动2位 "110100"; Bitset leftShift(size_t n,bool extendBits=false)const; //右移动n位,返回新的Bitset //extendBits=false "1101" 右移动2位 "0011"; //extendBits=true "1101" 右移动2位 "001101"; Bitset rightShift(size_t n, bool extendBits = false) const; public: virtual uint32_t getByteArraySize(); // returns the size of the required byte array. virtual void loadFromByteArray(const unsigned char * data); // load this object using the byte array. virtual void storeToByteArray(unsigned char ** data, uint32_t& length) ; // store this object in the byte array. };
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值