91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言中位圖怎么實現

發布時間:2021-05-31 14:23:43 來源:億速云 閱讀:143 作者:小新 欄目:開發技術

這篇文章主要介紹C語言中位圖怎么實現,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

本文實例為大家分享了C語言位圖及位圖的實現具體代碼,供大家參考,具體內容如下

1.概念

位圖(bitset)是一種常用的數據結構,常用在給一個很大范圍的數,判斷其中的一個數是不是在其中。在索引、數據壓縮方面有很大的應用。

位圖是用數組實現的,數組的每一個元素的每一個二進制位都表示一個數據,0表示該數據不存在,1表示該數據存在。

2.C++庫中bitset的使用

3.bitset的簡單實現

C語言中位圖怎么實現

當我們存放一個數據時的思路是:

1)確定數據在哪個區間上,即_bitSet的第幾個元素上,_bitSet是順序表,每個元素是char類型,value/8可得到

2)確定數據在哪個區間的哪個bit位上,value%8可以得到

3)找到該位置后,將bit位置1

4)重置的時候,將該bit位置0

#pragma once
#include<vector>
 
//只能用于整型,節省空間 
class BitSet
{
public:
 BitSet(size_t range)
 {
  //當range為8以下的時候,會開辟0個空間,會出錯
  _bitSet.resize(range/8+1,0);
 }
 
 void Set(size_t value)
 {
  size_t index = value / 8;  //value>>3
  size_t pos = value % 8;
 
  _bitSet[index] |= (1<<pos); //置1:或1
 }
 
 void ReSet(size_t value) //重置
 {
  size_t index = value / 8;
  size_t pos = value % 8;
 
  _bitSet[index] &= ~(1<<pos); //置0: 與0
 }
 
 bool Test(size_t value) //檢測
 {
  size_t index = value / 8;
  size_t pos = value % 8;
  
  return _bitSet[index] & (1<<pos);
 
 }
 
protected:
 vector<char> _bitSet;
};
 
void TestBitMap()
{
 BitSet b(-1); //-1轉為無符號數就是最大值
 b.Set(5);
 b.Set(999);
 b.Set(1022);
 b.Set(111110000);
 
 cout<<b.Test(5)<<endl;
 cout<<b.Test(100)<<endl; //100不在位圖當中
 cout<<b.Test(999)<<endl;
 cout<<b.Test(1022)<<endl;
 cout<<b.Test(111110000)<<endl;
}

C語言中位圖怎么實現

以上是“C語言中位圖怎么實現”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥芬河市| 太保市| 江华| 松潘县| 灵宝市| 顺平县| 且末县| 郴州市| 涞水县| 临潭县| 衡东县| 拜城县| 柘荣县| 金堂县| 鄂温| 宽城| 高碑店市| 来安县| 鄄城县| 上林县| 安宁市| 疏附县| 叶城县| 棋牌| 康马县| 马关县| 梁山县| 湖北省| 文水县| 内江市| 溧水县| 峨眉山市| 商丘市| 乌兰察布市| 志丹县| 沂水县| 城步| 凤阳县| 吉首市| 墨脱县| 壶关县|