c++ bitset詳解
bitset
使用bitset需要添加頭文件bitset ,bitset是一種特殊的容器 ,bitset數組中 ,每個成員隻裝1bit位的數據 , 即隻能是0 或 1。
bitset 的基本用法 :
初始化bitset容器
bitset<‘size’> 容器名;未初始化容器數據,會默認每位都是0
也可以給一個具體的初始化:存入int數據
bitset<‘size’> 容器名(‘num’);
會將num以二進制形式儲存在bitset中,如果初始化的容器位數不夠 ,會截取num二進制形式下的左邊部分,如果bitset容器過大,會把多於的位用0填充;
也可以初始化裝入隻含0和1的字符串:
biset<‘size’> 容器名(’str‘);註 若str中含除0 1 外的字符會報錯
容器會將str原樣儲存在每一位中,若容器過小會優先儲存str的左邊部分,過大則用0補足
代碼示例:
bitset<10> a;//每個成員隻能裝0 或1 ,默認為0 for(int i = 0 ; i < 10 ; i++) cout<<a[0];//可以以數組形式索引bitset容器 cout<<endl; bitset<5> a1(12);//把10以二進制形式存入,容器多餘的位用0補齊 cout<<a1<<endl;//01100 for(int i = 0 ; i < 5 ; i++) cout<<a1[i];//00110 註 bitset容器以數組形式索引時是從右往左索引 cout<<endl; bitset<5> a2("0100"); cout<<a2<<endl;//00100
也可以使用二維形式的bitset容器(感覺像是二維)
bitset<‘size’> 容器名[n];
n表示初始化n個size字節的bitset容器
bitset<5> b[4]; for(int i = 0 ; i < 4 ; i++) { b[i] = i; cout<<b[i]<<endl; }
可以向b[i]中存入數據,也可以索引某個位
cout<<b[1][0]<<endl;
輸出結果1;
betsit用於數據壓縮
bitset<1000> a;//可以用於表示1000以下的正整數,若a[i] = 1 , 則表示存儲的有i這個數,這樣一個容器就可以壓縮存儲很多不同的數據 a = a<<i;//這樣操作就可以給a中壓縮存儲的數據都加上i,可大幅降低時間復雜度 a = a>>i;//同理也可以都減去i , 之後索引哪些位是1就可以知道計算後的結果
總結
本篇文章就到這裡瞭,希望能給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!