bitset练习

    标准库提供的bitset类简化了位集的处理。bitset其实很简单,只是因为它不如vector和string那样常用,所以很多人都放弃了这么好用的工具。


头文件:#include<bitset>


常用的成员函数:
b.any() b中是否存在置为1的二进制位?
b.none() b中不存在置为1的二进制位吗?
b.count() b中置为1的二进制位的个数
b.size() b中二进制位数的个数
b[pos] 访问b中在pos处二进制位
b.test(pos) b中在pos处的二进制位置为1么?
b.set() 把b中所有二进制位都置为1
b.set(pos) 把b中在pos处的二进制位置为1
b.reset( ) 把b中所有二进制位都置为0
b.reset( pos ) 把b中在pos处的二进制位置置为0
b.flip( ) 把b中所有二进制位逐位取反
b.flip( pos ) 把b中在pos处的二进制位取反
b.to_ulong( ) 把b中同样的二进制位返回一个unsigned
os << b 把b中的位集输出到os流



参考资料:《C++ Primer》

MSDN:http://msdn.microsoft.com/zh-cn/library/zfae7kt8.aspx

#include <iostream>
#include <string>
#include <bitset>
using namespace std;
int main()
{
	string str = "10011";
	bitset<9>bitvec(str);// 0,1,4为置1,其余为0

	string str2 = "Hello,world";
	//bitset<500>b2(str2); //error

	size_t bits_set = bitvec.size();
	cout << "bitvec.size()" << bits_set << endl;
	cout << bitvec << endl; //可以直接输出
	cout << "ulong = " <<bitvec.to_ulong() <<endl << endl;

	bitvec.flip();
	bits_set = bitvec.size();
	cout << "bitvec.size()" << bits_set << endl;
	cout << bitvec << endl;
	cout << "ulong = " <<bitvec.to_ulong() <<endl << endl;

	bitvec.reset();
	bits_set = bitvec.size();
	cout << "bitvec.size()" << bits_set << endl;
	cout << bitvec << endl;
	cout << "ulong = " <<bitvec.to_ulong() <<endl << endl;
	return 0;
}

执行结果如下所示:

bitvec.size()9
000010011
ulong = 19


bitvec.size()9
111101100
ulong = 492


bitvec.size()9
000000000
ulong = 0


请按任意键继续. . .


你可能感兴趣的:(bitset练习)