基于C++ bitset常用函數(shù)及運算符(詳解)
C++ bitset——高端壓位卡常題必備STL
------------------------------------------------------------
以下內(nèi)容翻譯自cplusplus.com,極大地鍛煉了我的英語能力。
bitset存儲二進制數(shù)位。
bitset就像一個bool類型的數(shù)組一樣,但是有空間優(yōu)化——bitset中的一個元素一般只占1 bit,相當于一個char元素所占空間的八分之一。
bitset中的每個元素都能單獨被訪問,例如對于一個叫做foo的bitset,表達式foo[3]訪問了它的第4個元素,就像數(shù)組一樣。
bitset有一個特性:整數(shù)類型和布爾數(shù)組都能轉(zhuǎn)化成bitset。
bitset的大小在編譯時就需要確定。如果你想要不確定長度的bitset,請使用(奇葩的)vector<bool>。
定義一個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的運算
bitset的運算就像一個普通的整數(shù)一樣,可以進行與(&)、或(|)、異或(^)、左移(<<)、右移(>>)等操作。
// 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的相關函數(shù)
對于一個叫做foo的bitset:
foo.size() 返回大?。ㄎ粩?shù))
foo.count() 返回1的個數(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é)果,如果超出范圍則報錯
foo.to_ullong() 返回它轉(zhuǎn)換為unsigned long long的結(jié)果,如果超出范圍則報錯
foo.to_string() 返回它轉(zhuǎn)換為string的結(jié)果
以上這篇基于C++ bitset常用函數(shù)及運算符(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持我們。
上一篇:C++數(shù)據(jù)結(jié)構(gòu)與算法之哈夫曼樹的實現(xiàn)方法
欄 目:C語言
本文標題:基于C++ bitset常用函數(shù)及運算符(詳解)
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1039.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 01-10深入理解C++中常見的關鍵字含義
- 01-10使用C++實現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10用C++實現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實現(xiàn)與遞歸實現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關鍵字的使用詳解
- 01-10深入C/C++浮點數(shù)在內(nèi)存中的存儲方式詳解
- 01-10基于atoi()與itoa()函數(shù)的內(nèi)部實現(xiàn)方法詳解


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