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

C++中bitset位圖介紹及模擬實現(xiàn)

 更新時間:2023年07月10日 10:26:39   作者:清擾077  
位圖就是用每一位來存放某種狀態(tài),適用于海量數(shù)據(jù),本文就介紹一下C++中bitset位圖介紹及模擬實現(xiàn),具有一定的參考價值,感興趣的可以了解一下

位圖介紹

一、位圖的引入

先來看下邊一道面試題:

給40億個不重復(fù)的無符號整數(shù),沒排過序。給一個無符號整數(shù),如何快速判斷一個數(shù)是否在這40億個數(shù)中。

經(jīng)過我們之前的學(xué)習(xí),我們可能會有以下的思路:

  • 對這些數(shù)進行排序,再通過二分算法,查找這個數(shù)是否存在
  • 插入到unordered_set中,使用find函數(shù)查找是否存在

上述方法看起來還不錯,二分查找算法時間復(fù)雜度為logN,而插入到unordered_set中時間復(fù)雜度為O(N),而查找時時間復(fù)雜度為O(1),但是都有一個問題就是要將空間不足,40億個無符號整形,需要160億字節(jié)的空間,大概就是16GB的空間,一般計算機的內(nèi)促都是4G或者8G,所以空間不足,此時就有了位圖的方法來解決:

數(shù)據(jù)是否在給定的整形數(shù)據(jù)中,結(jié)果是在或者不在,剛好是兩種狀態(tài),那么可以使用一個二進制比特位來代表數(shù)據(jù)是否存在的信息,如果二進制比特位為1,代表存在,為0代表不存在。比如:

對于上圖來說,有一個整形數(shù)組,我們可以使用直接定址法對數(shù)組的數(shù)據(jù)進行映射,但是與之前不同的是,此時只是使用一個比特位來代表一個整形數(shù)據(jù),當這個數(shù)存在時,比特位置1,不存在時,比特位置0,此時就可以大大節(jié)省空間資源,無符號整數(shù)只有2的32次方個,所以最多開2的32次方個空間,一個空間為一個比特,所以最終只需要512MB的空間。但是我們不能按照位來空間,最少必須一個字節(jié),所以我們就每次開一個字節(jié)的空間,也就是8個比特位,將8位當做一個整體來處理,對要保存的數(shù)據(jù)除8就是第幾個字節(jié),對保存的數(shù)據(jù)模8就是在這個字節(jié)中的第幾個位置。

二、位圖的概念

所謂位圖,就是用每一位來存放某種狀態(tài),適用于海量數(shù)據(jù),數(shù)據(jù)無重復(fù)的場景。通常是用來判斷某個數(shù)據(jù)存不存在的。

那么位圖還有哪些應(yīng)用呢?

  • 快速查找某個數(shù)據(jù)是否在一個集合中
  • 排序 + 去重
  • 求兩個集合的交集、并集等
  • 操作系統(tǒng)中磁盤塊標記

位圖模擬實現(xiàn)

一、構(gòu)造函數(shù)

由于不能按位開空間,所以我們選擇每次開一個字節(jié)的空間,由于有范圍最大為N,一位關(guān)聯(lián)一個數(shù)據(jù),所以需要開N/8個字節(jié)的空間,但是有時可能不能整除,所以要開N/8+1個字節(jié)的空間。所以

直接在構(gòu)造函數(shù)中開好空間:

bitset()
		{
			_bits.resize(N / 8 + 1,0);
		}

二、set,reset,test函數(shù)

set函數(shù)的作用是對位圖中的某一位進行填充

i就表示是第幾個字節(jié),而j表示該位在該字節(jié)中的第幾位,所以對1進行左移j位后與該字節(jié)按位或,按位或的作用時不論該位為0還是為1,都將該位變?yōu)?.

void set(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			_bits[i] |= (1 << j);
		}

reset的作用是將某一位清空

同樣的將要清空的那一位置為0,進行按位與,不論原本該位是0還是1,都將該位置0

void reset(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			_bits[i] &= ~(1 << j);
		}

test的作用是檢測位圖中某一位是否存在

bool test(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			return _bits[i] & (1 << j);
		}

三、代碼測試

void test_bit_set1()
	{
		bitset<100> bs1;
		bs1.set(8);
		bs1.set(9);
		bs1.set(20);
		cout << bs1.test(8) << endl;
		cout << bs1.test(9) << endl;
		cout << bs1.test(20) << endl;
		bs1.reset(8);
		bs1.reset(9);
		bs1.reset(20);
		cout << bs1.test(8) << endl;
		cout << bs1.test(9) << endl;
		cout << bs1.test(20) << endl;
	}

四、完整代碼

namespace tmt
{
	template<size_t N>
	class bitset
	{
	public:
		bitset()
		{
			_bits.resize(N / 8 + 1,0);
		}
		void set(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			_bits[i] |= (1 << j);
		}
		void reset(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			_bits[i] &= ~(1 << j);
		}
		bool test(size_t x)
		{
			int i = x / 8;
			int j = x % 8;
			return _bits[i] & (1 << j);
		}
	private:
		vector<char> _bits;
	};
	void test_bit_set1()
	{
		bitset<100> bs1;
		bs1.set(8);
		bs1.set(9);
		bs1.set(20);
		cout << bs1.test(8) << endl;
		cout << bs1.test(9) << endl;
		cout << bs1.test(20) << endl;
		bs1.reset(8);
		bs1.reset(9);
		bs1.reset(20);
		cout << bs1.test(8) << endl;
		cout << bs1.test(9) << endl;
		cout << bs1.test(20) << endl;
	}

到此這篇關(guān)于C++中bitset位圖介紹及模擬實現(xiàn)的文章就介紹到這了,更多相關(guān)C++ bitset位圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++實現(xiàn)LeetCode(676.實現(xiàn)神奇字典)

    C++實現(xiàn)LeetCode(676.實現(xiàn)神奇字典)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(676.實現(xiàn)神奇字典),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++編程中用put輸出單個字符和cin輸入流的用法

    C++編程中用put輸出單個字符和cin輸入流的用法

    這篇文章主要介紹了C++編程中用put輸出單個字符和cin輸入流的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C++和C中const的區(qū)別詳解

    C++和C中const的區(qū)別詳解

    這篇文章主要為大家介紹了C++和C中const的區(qū)別,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • 淺談C語言中strcpy,strcmp,strlen,strcat函數(shù)原型

    淺談C語言中strcpy,strcmp,strlen,strcat函數(shù)原型

    下面小編就為大家?guī)硪黄獪\談C語言中strcpy,strcmp,strlen,strcat函數(shù)原型。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • C/C++實現(xiàn)枚舉網(wǎng)上鄰居信息的示例詳解

    C/C++實現(xiàn)枚舉網(wǎng)上鄰居信息的示例詳解

    在Windows系統(tǒng)中,通過網(wǎng)絡(luò)鄰居可以方便地查看本地網(wǎng)絡(luò)中的共享資源和計算機,本文將介紹一個簡單的C++程序,使用Windows API枚舉網(wǎng)絡(luò)鄰居信息,并獲取對端名稱、本機名稱、主機名稱以及主機IP等信息,文中通過代碼示例給大家講解非詳細,需要的朋友可以參考下
    2023-12-12
  • C++實現(xiàn)LeetCode(84.直方圖中最大的矩形)

    C++實現(xiàn)LeetCode(84.直方圖中最大的矩形)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(84.直方圖中最大的矩形),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 淺談哈希表存儲效率一般不超過50%的原因

    淺談哈希表存儲效率一般不超過50%的原因

    下面小編就為大家?guī)硪黄獪\談哈希表存儲效率一般不超過50%的原因。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • C++解析Json的方法詳解【jsoncpp】

    C++解析Json的方法詳解【jsoncpp】

    這篇文章主要介紹了C++解析Json的方法,結(jié)合實例形式分析了C++操作json格式數(shù)據(jù)的相關(guān)實現(xiàn)技巧與注意事項,需要的朋友可以參考下
    2017-06-06
  • C++ 實現(xiàn)求最大公約數(shù)和最小公倍數(shù)

    C++ 實現(xiàn)求最大公約數(shù)和最小公倍數(shù)

    這篇文章主要介紹了c++ 實現(xiàn)求最大公約數(shù)和最小公倍數(shù)的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • 圖解AVL樹數(shù)據(jù)結(jié)構(gòu)輸入與輸出及實現(xiàn)示例

    圖解AVL樹數(shù)據(jù)結(jié)構(gòu)輸入與輸出及實現(xiàn)示例

    這篇文章主要為大家介紹了C++圖解AVL樹數(shù)據(jù)結(jié)構(gòu)輸入與輸出操作示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05

最新評論