基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)
C++ bitset——高端壓位卡常題必備STL
------------------------------------------------------------
以下內(nèi)容翻譯自cplusplus.com,極大地鍛煉了我的英語能力。
bitset存儲(chǔ)二進(jìn)制數(shù)位。
bitset就像一個(gè)bool類型的數(shù)組一樣,但是有空間優(yōu)化——bitset中的一個(gè)元素一般只占1 bit,相當(dāng)于一個(gè)char元素所占空間的八分之一。
bitset中的每個(gè)元素都能單獨(dú)被訪問,例如對(duì)于一個(gè)叫做foo的bitset,表達(dá)式foo[3]訪問了它的第4個(gè)元素,就像數(shù)組一樣。
bitset有一個(gè)特性:整數(shù)類型和布爾數(shù)組都能轉(zhuǎn)化成bitset。
bitset的大小在編譯時(shí)就需要確定。如果你想要不確定長度的bitset,請(qǐng)使用(奇葩的)vector<bool>。
定義一個(gè)bitset
// constructing bitsets
#include <iostream>  // std::cout
#include <string>   // std::string
#include <bitset>   // std::bitset
int main ()
{
 std::bitset<16> foo;
 std::bitset<16> bar (0xfa2);
 std::bitset<16> baz (std::string("0101111001"));
 std::cout << "foo: " << foo << '\n';
 std::cout << "bar: " << bar << '\n';
 std::cout << "baz: " << baz << '\n';
 return 0;
}
輸出結(jié)果:
foo: 0000000000000000 bar: 0000111110100010 baz: 0000000101111001
bitset的運(yùn)算
bitset的運(yùn)算就像一個(gè)普通的整數(shù)一樣,可以進(jìn)行與(&)、或(|)、異或(^)、左移(<<)、右移(>>)等操作。
// bitset operators
#include <iostream>  // std::cout
#include <string>   // std::string
#include <bitset>   // std::bitset
int main ()
{
 std::bitset<4> foo (std::string("1001"));
 std::bitset<4> bar (std::string("0011"));
 std::cout << (foo^=bar) << '\n';  // 1010 (XOR,assign)
 std::cout << (foo&=bar) << '\n';  // 0010 (AND,assign)
 std::cout << (foo|=bar) << '\n';  // 0011 (OR,assign)
 std::cout << (foo<<=2) << '\n';  // 1100 (SHL,assign)
 std::cout << (foo>>=1) << '\n';  // 0110 (SHR,assign)
 std::cout << (~bar) << '\n';   // 1100 (NOT)
 std::cout << (bar<<1) << '\n';   // 0110 (SHL)
 std::cout << (bar>>1) << '\n';   // 0001 (SHR)
 std::cout << (foo==bar) << '\n';  // false (0110==0011)
 std::cout << (foo!=bar) << '\n';  // true (0110!=0011)
 std::cout << (foo&bar) << '\n';  // 0010
 std::cout << (foo|bar) << '\n';  // 0111
 std::cout << (foo^bar) << '\n';  // 0101
 return 0;
}
上面代碼的輸出結(jié)果見注釋。(注意,這段代碼涉及賦值操作)
bitset的相關(guān)函數(shù)
對(duì)于一個(gè)叫做foo的bitset:
foo.size() 返回大小(位數(shù))
foo.count() 返回1的個(gè)數(shù)
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() 返回它轉(zhuǎn)換為unsigned long的結(jié)果,如果超出范圍則報(bào)錯(cuò)
foo.to_ullong() 返回它轉(zhuǎn)換為unsigned long long的結(jié)果,如果超出范圍則報(bào)錯(cuò)
foo.to_string() 返回它轉(zhuǎn)換為string的結(jié)果
以上這篇基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持我們。
上一篇:C++數(shù)據(jù)結(jié)構(gòu)與算法之哈夫曼樹的實(shí)現(xiàn)方法
欄 目:C語言
下一篇:C++使用htslib庫讀入和寫出bam文件的實(shí)例
本文標(biāo)題:基于C++ bitset常用函數(shù)及運(yùn)算符(詳解)
本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1039.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
 - 01-10深入理解C++中常見的關(guān)鍵字含義
 - 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
 - 01-10c++中inline的用法分析
 - 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
 - 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
 - 01-10C++大數(shù)模板(推薦)
 - 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解
 - 01-10深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
 - 01-10基于atoi()與itoa()函數(shù)的內(nèi)部實(shí)現(xiàn)方法詳解
 


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
 - 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
 - 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
 - 04-02c語言用函數(shù)寫分段 用c語言表示分段
 - 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
 - 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
 - 04-02c語言沒有round函數(shù) round c語言
 - 04-02c語言分段函數(shù)怎么求 用c語言求分段
 - 04-02C語言中怎么打出三角函數(shù) c語言中怎
 - 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
 
隨機(jī)閱讀
- 01-10C#中split用法實(shí)例總結(jié)
 - 01-11ajax實(shí)現(xiàn)頁面的局部加載
 - 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
 - 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
 - 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
 - 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
 - 04-02jquery與jsp,用jquery
 - 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
 - 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
 - 01-10delphi制作wav文件的方法
 


