bitset类似于数组结构,但是它的每一个元素之能是0或1,每个元素仅用1bit空间。 应用是须加入#include <bitset>
Determine if all characters of a string are unique.
模式识别:凡是题目中涉及unique的字眼或者是否存在直觉考虑用bitset。
bool isUnique(string input) { bitset<256> hashMap; // 利用ADCII值作为数字下标的映射 for (int i = 0; i < input.length(); i++) { if (hashMap[(int)input[i]]) { return false; // 如果出现相同的则返回true } hashMap[(int)input[i]] = 1; } return true; // true表示都是unique }此外,可以通过 [ ] 访问元素(类似数组),注意最低位下标为0,如下:
bitset <4> foo("1011"); cout << foo[0] << endl; // 1 cout << foo[1] << endl; // 1 cout << foo[2] << endl; // 0 cout << foo[3] << endl; // 1test函数会对下标越界作出检查,而通过 [ ] 访问元素却不会经过下标检查,所以,在两种方式通用的情况下,选择test函数更安全一些
bitset<8> foo ("10011011"); cout << foo.flip(2) << endl; //10011111 (flip函数传参数时,用于将参数位取反,本行代码将foo下标2处"反转",即0变1,1变0 cout << foo.flip() << endl; //01100000 (flip函数不指定参数时,将bitset每一位全部取反 cout << foo.set() << endl; //11111111 (set函数不指定参数时,将bitset的每一位全部置为1 cout << foo.set(3,0) << endl; //11110111 (set函数指定两位参数时,将第一参数位的元素置为第二参数的值,本行对foo的操作相当于foo[3]=0 cout << foo.set(3) << endl; //11111111 (set函数只有一个参数时,将参数下标处置为1 cout << foo.reset(4) << endl; //11101111 (reset函数传一个参数时将参数下标处置为0 cout << foo.reset() << endl; //00000000 (reset函数不传参数时将bitset的每一位全部置为0转换函数
bitset<8> foo ("10011011"); string s = foo.to_string(); //将bitset转换成string类型 unsigned long a = foo.to_ulong(); //将bitset转换成unsigned long类型 unsigned long long b = foo.to_ullong(); //将bitset转换成unsigned long long类型 cout << s << endl; //10011011 cout << a << endl; //155 cout << b << endl; //155