下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第go數(shù)據(jù)結(jié)構(gòu)和算法BitMap原理及實(shí)現(xiàn)示例目錄1.BitMap介紹如何判斷數(shù)字在bit數(shù)組的位置設(shè)置數(shù)據(jù)到bit數(shù)組從bit數(shù)組中清除數(shù)據(jù)數(shù)字是否在bit數(shù)組中2.Go語(yǔ)言位運(yùn)算左移右移使用^和位移運(yùn)算來(lái)給某一位置03.BitMap的Go語(yǔ)言實(shí)現(xiàn)定義創(chuàng)建BitMap結(jié)構(gòu)將數(shù)據(jù)添加到BitMap從BitMap中刪除數(shù)據(jù)判斷BitMap中是否存在指定的數(shù)據(jù)
1.BitMap介紹
BitMap可以理解為通過(guò)一個(gè)bit數(shù)組來(lái)存儲(chǔ)特定數(shù)據(jù)的一種數(shù)據(jù)結(jié)構(gòu)。BitMap常用于對(duì)大量整形數(shù)據(jù)做去重和查詢。
在這類查找中,我們可以通過(guò)map數(shù)據(jù)結(jié)構(gòu)進(jìn)行查找。但如果數(shù)據(jù)量比較大map數(shù)據(jù)結(jié)構(gòu)將會(huì)大量占用內(nèi)存。
BitMap用一個(gè)比特位來(lái)映射某個(gè)元素的狀態(tài),所以這種數(shù)據(jù)結(jié)構(gòu)是非常節(jié)省存儲(chǔ)空間的。
BitMap用途
BitMap用于數(shù)據(jù)去重
BitMap可用于數(shù)據(jù)的快速查找,判重。BitMap用于快速排序
BitMap由于其本身的有序性和唯一性,可以實(shí)現(xiàn)快速排序:將其加入bitmap中,然后再遍歷獲取出來(lái),從而得到排序的結(jié)果。
如何判斷數(shù)字在bit數(shù)組的位置
在后面的代碼中,我們使用[]byte來(lái)存儲(chǔ)bit數(shù)據(jù),由于一個(gè)byte有8個(gè)二進(jìn)制位。因此:
數(shù)字/8=數(shù)字在字節(jié)數(shù)組中的位置。數(shù)字%8=數(shù)字在當(dāng)前字節(jié)中的位置。
例如:數(shù)字10,10/8=1,即數(shù)字10對(duì)應(yīng)的字節(jié)數(shù)組的位置為:110%8=2,即數(shù)字10對(duì)應(yīng)的當(dāng)前字節(jié)的位置為:2
設(shè)置數(shù)據(jù)到bit數(shù)組
num/8得到數(shù)字在字節(jié)數(shù)組中的位置=rownum%8得到數(shù)字在當(dāng)前字節(jié)中的位置=col將1左移col位,然后和以前的數(shù)據(jù)做|運(yùn)算,這樣就可以將col位置的bit替換成1了。
從bit數(shù)組中清除數(shù)據(jù)
num/8得到數(shù)字在字節(jié)數(shù)組中的位置=rownum%8得到數(shù)字在當(dāng)前字節(jié)中的位置=col將1左移col位,然后對(duì)取反,再與當(dāng)前值做,這樣就可以將col位置的bit替換成0了。
數(shù)字是否在bit數(shù)組中
num/8得到數(shù)字在字節(jié)數(shù)組中的位置=rownum%8得到數(shù)字在當(dāng)前字節(jié)中的位置=col將1左移col位,然后和以前的數(shù)據(jù)做運(yùn)算,若該字節(jié)的值!=0,則說(shuō)明該位置是1,則數(shù)據(jù)在bit數(shù)組中,否則數(shù)據(jù)不在bit數(shù)組中。
2.Go語(yǔ)言位運(yùn)算
在Go語(yǔ)言中支持以下幾種操作位的方式:
按位與:兩者全為1結(jié)果為1,否則結(jié)果為0|按位或:兩者有一個(gè)為1結(jié)果為1,否則結(jié)果為0^按位異或:兩者不同結(jié)果為1,否則結(jié)果為0^按位與非:是與和非操作符的簡(jiǎn)寫形式按位左移:按位右移:
左移
將二進(jìn)制向左移動(dòng),右邊空出的位用0填補(bǔ),高位左移溢出則舍棄該高位。
由于每次移位數(shù)值會(huì)翻倍,所以通常用代替乘2操作。當(dāng)然這是建立在移位沒(méi)有溢出的情況。
例如:13相當(dāng)于18=8,34相當(dāng)于316=48
右移
將整數(shù)二進(jìn)制向右移動(dòng),左邊空出的位用0或者1填補(bǔ)。正數(shù)用0填補(bǔ),負(fù)數(shù)用1填補(bǔ)。
負(fù)數(shù)在內(nèi)存中的二進(jìn)制最高位為符號(hào)位使用1表示,所以為了保證移位之后符號(hào)位的正確性,所以需要在高位補(bǔ)1。
相對(duì)于左移來(lái)說(shuō),右移通常用來(lái)代替除2操作。
例如:243相當(dāng)于248=3
使用^和位移運(yùn)算來(lái)給某一位置0
這個(gè)操作符通常用于清空對(duì)應(yīng)的標(biāo)志位,例如a=00111010,如果想清空第二位,則可以這樣操作:
a^00000010=00111000
3.BitMap的Go語(yǔ)言實(shí)現(xiàn)
接下來(lái)我們給出BitMap的Go語(yǔ)言實(shí)現(xiàn),目前代碼已經(jīng)上傳到github中,下載地址
定義
首先給出BitMap結(jié)構(gòu)的定義:
typeBitMapstruct{
bits[]byte
vmaxuint
}
創(chuàng)建BitMap結(jié)構(gòu)
funcNewBitMap(max_val...uint)*BitMap{
varmaxuint=8192
iflen(max_val)0max_val[0]0{
max=max_val[0]
bm:=BitMap{}
bm.vmax=max
sz:=(max+7)/8
bm.bits=make([]byte,sz,sz)
returnbm
}
將數(shù)據(jù)添加到BitMap
func(bm*BitMap)Set(numuint){
ifnumbm.vmax{
bm.vmax+=1024
ifbm.vmaxnum{
bm.vmax=num
dd:=int(num+7)/8-len(bm.bits)
ifdd0{
tmp_arr:=make([]byte,dd,dd)
bm.bits=append(bm.bits,tmp_arr...)
//將1左移num%8后,然后和以前的數(shù)據(jù)做|,這樣就替換成1了
bm.bits[num/8]|=1(num%8)
}
從BitMap中刪除數(shù)據(jù)
func(bm*BitMap)UnSet(numuint){
ifnumbm.vmax{
return
//^:將1左移num%8后,然后進(jìn)行與非運(yùn)算,將運(yùn)算符左邊數(shù)據(jù)相異的位保留,相同位清零
bm.bits[num/8]^=1(num%8)
}
判斷BitMap中是否存在指定的數(shù)據(jù)
func(bm*BitMap)Check(numuint)bool{
ifnumbm.vmax{
returnfalse
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 警務(wù)室調(diào)解制度
- 用電基礎(chǔ)知識(shí)培訓(xùn)
- 2025高一政治期末模擬卷01(考試版)【測(cè)試范圍:必修1全冊(cè)+必修2全冊(cè)】(新高考用)含答案
- 醫(yī)院愛崗敬業(yè)培訓(xùn)課件
- 國(guó)考公安考試試題及答案
- 2026年上半年浙江杭州市婦產(chǎn)科醫(yī)院(杭州市婦幼保健院)高層次、緊缺專業(yè)人才招聘15人(總)備考考試試題附答案解析
- 2026某事業(yè)單位招聘保潔崗位1人備考考試題庫(kù)附答案解析
- JIS D 9101-2012 自行車術(shù)語(yǔ)標(biāo)準(zhǔn) Cycles - Terminology
- 2026福建福州市平潭綜合實(shí)驗(yàn)區(qū)黨工委黨校(區(qū)行政學(xué)院、區(qū)社會(huì)主義學(xué)院)招聘編外工作人員1人備考考試題庫(kù)附答案解析
- 2026福建龍巖鑫達(dá)彩印有限公司龍巖鑫利來(lái)酒店分公司(第一批)招聘3人參考考試試題附答案解析
- 2025屆高考小說(shuō)專題復(fù)習(xí)-小說(shuō)敘事特征+課件
- 部編版二年級(jí)下冊(cè)寫字表字帖(附描紅)
- 干部履歷表(中共中央組織部2015年制)
- GB/T 5657-2013離心泵技術(shù)條件(Ⅲ類)
- GB/T 3518-2008鱗片石墨
- GB/T 17622-2008帶電作業(yè)用絕緣手套
- GB/T 1041-2008塑料壓縮性能的測(cè)定
- 400份食物頻率調(diào)查問(wèn)卷F表
- 滑坡地質(zhì)災(zāi)害治理施工
- 實(shí)驗(yàn)動(dòng)物從業(yè)人員上崗證考試題庫(kù)(含近年真題、典型題)
- 可口可樂(lè)-供應(yīng)鏈管理
評(píng)論
0/150
提交評(píng)論