亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言位圖及位圖的實現(xiàn)

 更新時間:2021年05月31日 17:15:01   作者:WhiteShirtI  
這篇文章主要為大家詳細(xì)介紹了C語言位圖及位圖的實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

1.概念

位圖(bitset)是一種常用的數(shù)據(jù)結(jié)構(gòu),常用在給一個很大范圍的數(shù),判斷其中的一個數(shù)是不是在其中。在索引、數(shù)據(jù)壓縮方面有很大的應(yīng)用。

位圖是用數(shù)組實現(xiàn)的,數(shù)組的每一個元素的每一個二進(jìn)制位都表示一個數(shù)據(jù),0表示該數(shù)據(jù)不存在,1表示該數(shù)據(jù)存在。

2.C++庫中bitset的使用

3.bitset的簡單實現(xiàn)

當(dāng)我們存放一個數(shù)據(jù)時的思路是:

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

2)確定數(shù)據(jù)在哪個區(qū)間的哪個bit位上,value%8可以得到

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

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

#pragma once
#include<vector>
 
//只能用于整型,節(jié)省空間 
class BitSet
{
public:
 BitSet(size_t range)
 {
  //當(dāng)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轉(zhuǎn)為無符號數(shù)就是最大值
 b.Set(5);
 b.Set(999);
 b.Set(1022);
 b.Set(111110000);
 
 cout<<b.Test(5)<<endl;
 cout<<b.Test(100)<<endl; //100不在位圖當(dāng)中
 cout<<b.Test(999)<<endl;
 cout<<b.Test(1022)<<endl;
 cout<<b.Test(111110000)<<endl;
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++利用eigen庫實現(xiàn)求歐拉角

    C++利用eigen庫實現(xiàn)求歐拉角

    這篇文章主要為大家詳細(xì)介紹了C++如何利用eigen庫自帶的matrix.eulerAngles()函數(shù)實現(xiàn)求歐拉角,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考下
    2023-11-11
  • 顯示內(nèi)存狀態(tài)示例分享

    顯示內(nèi)存狀態(tài)示例分享

    這篇文章主要介紹了顯示內(nèi)存狀態(tài)示例,代碼簡單,下面直接看代碼,需要的朋友可以參考下
    2014-02-02
  • C++棧(stack)的模板類實現(xiàn)代碼

    C++棧(stack)的模板類實現(xiàn)代碼

    這篇文章主要為大家詳細(xì)介紹了C++棧(stack)的模板類實現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Qt實現(xiàn)繪制多個設(shè)備的流量曲線圖詳解

    Qt實現(xiàn)繪制多個設(shè)備的流量曲線圖詳解

    這篇文章主要為大家詳細(xì)介紹了如何使用Qt開發(fā)繪制多個設(shè)備的流量曲線圖,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Qt有一定的幫助,需要的可以參考一下
    2023-01-01
  • C++實現(xiàn)LeetCode(122.買股票的最佳時間之二)

    C++實現(xiàn)LeetCode(122.買股票的最佳時間之二)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(122.買股票的最佳時間之二),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 單元測試代碼覆蓋率解析

    單元測試代碼覆蓋率解析

    單元測試(unit testing),是指對軟件中的最小可測試單元進(jìn)行檢查和驗證。動態(tài)分析就是通過觀察軟件運(yùn)行時的動作,來提供執(zhí)行跟蹤,時間分析,以及測試覆蓋度方面的信息。下面我們來詳細(xì)了解下吧
    2019-06-06
  • C語言簡明清晰講解結(jié)構(gòu)體

    C語言簡明清晰講解結(jié)構(gòu)體

    C語言結(jié)構(gòu)體(Struct)從本質(zhì)上講是一種自定義的數(shù)據(jù)類型,只不過這種數(shù)據(jù)類型比較復(fù)雜,是由 int、char、float 等基本類型組成的。你可以認(rèn)為結(jié)構(gòu)體是一種聚合類型
    2022-05-05
  • Matlab實現(xiàn)貪吃蛇小游戲的示例代碼

    Matlab實現(xiàn)貪吃蛇小游戲的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用Matlab實現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++實現(xiàn)一鍵關(guān)閉桌面的示例代碼

    C++實現(xiàn)一鍵關(guān)閉桌面的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C++實現(xiàn)一鍵關(guān)閉桌面的功能,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的小伙伴可以了解一下
    2023-07-07
  • C語言將音視頻時鐘同步封裝成通用模塊的方法

    C語言將音視頻時鐘同步封裝成通用模塊的方法

    視頻的時鐘基于視頻幀的時間戳,由于視頻是通過一定的幀率渲染的,采用直接讀取當(dāng)前時間戳的方式獲取時鐘會造成一定的誤差,精度不足,這篇文章主要介紹了c語言將音視頻時鐘同步封裝成通用模塊,需要的朋友可以參考下
    2022-09-09

最新評論