python 32bit數據結構_python實現bitmap數據結構詳解

bitmap是很常見的算法設計,例如用以Bloom Filter中;用以無反復整數金額的排列這些。bitmap一般根據數組來完成,數組中每一個原素能夠當做是一系列二進制數,全部元素組成更高的二進制結合。針對Python而言,整數金額種類默認設置是有標記種類,因此 一個整數金額的能用十位數為31位。

bitmap完成構思

bitmap是用以對每一位開展實際操作。舉例來說,一個Python數組包括4個32位系統有標記整形,則一共能用位為4 * 31 = 124位。假如要在第90個二進制位上實際操作,則要先獲得到實際操作數組的第幾個原素,再獲得相對的位數據庫索引,隨后實行實際操作。

圖中所顯示為一個32位系統整形,在Python中默認設置是有標記種類,最大位為標記位,bitmap不可以應用它。左側是上位,右側是底位,最少位為第0位。

bitmap是用以對每一位開展實際操作。舉例來說,一個Python數組包括4個32位系統有標記整形,則一共能用位為4 * 31 = 124位。假如要在第90個二進制位上實際操作,則要先獲得到實際操作數組的第幾個原素,再獲得相對的位數據庫索引,隨后實行實際操作。

復位bitmap

最先必須復位bitmap。拿90這一整數金額而言,由于單獨整形只有應用31位,因此 90除于31并向上取整則可獲知必須好多個數組原素。編碼以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = int((max 31 – 1) / 31) #向上取整

if __name__ == ‘__main__’:

bitmap = Bitmap(90)

print ‘必須 %d 個原素。’ % bitmap.size

編碼以下:

$ python bitmap.py

必須 3 個原素。

測算在數組中的數據庫索引

測算在數組中的數據庫索引實際上是跟以前測算數組尺寸是一樣的。只不過是以前是對最大值測算,如今換為任一必須儲存的整數金額。可是有一點不一樣,測算在數組中的數據庫索引是向下取整,因此 必須改動calcElemIndex方式的完成。編碼改成以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = self.calcElemIndex(max, True)

self.array = [0 for i in range(self.size)]

def calcElemIndex(self, num, up=False):

”’up為True則為向上取整, 不然為向下取整”’

if up:

return int((num 31 – 1) / 31) #向上取整

return num / 31

if __name__ == ‘__main__’:

bitmap = Bitmap(90)

print ‘數組必須 %d 個原素。’ % bitmap.size

print ’47 應儲存在第 %d 個數組原素上。’ % bitmap.calcElemIndex(47)

編碼以下:

$ python bitmap.py

數組必須 3 個原素。

47 應儲存在第 1 個數組原素上。

因此 獲得較大 整數金額很重要,不然有可能建立的數組容下下不來一些數據信息。

測算在數組原素中的位數據庫索引

數組原素中的位數據庫索引能夠根據取模運算來獲得。令需儲存的整數金額跟31牙模型就可以獲得位數據庫索引。編碼改成以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = self.calcElemIndex(max, True)

self.array = [0 for i in range(self.size)]

def calcElemIndex(self, num, up=False):

”’up為True則為向上取整, 不然為向下取整”’

if up:

return int((num 31 – 1) / 31) #向上取整

return num / 31

def calcBitIndex(self, num):

return num % 31

if __name__ == ‘__main__’:

bitmap = Bitmap(90)

print ‘數組必須 %d 個原素。’ % bitmap.size

print ’47 應儲存在第 %d 個數組原素上。’ % bitmap.calcElemIndex(47)

print ’47 應儲存在第 %d 個數組原素的第 %d 位上。’ % (bitmap.calcElemIndex(47), bitmap.calcBitIndex(47),)

別忘記是以第0位算起哦。

置1實際操作

二進制位默認設置是0,將某部位1則表明在這里位儲存了數據信息。編碼改成以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = self.calcElemIndex(max, True)

self.array = [0 for i in range(self.size)]

def calcElemIndex(self, num, up=False):

”’up為True則為向上取整, 不然為向下取整”’

if up:

return int((num 31 – 1) / 31) #向上取整

return num / 31

def calcBitIndex(self, num):

return num % 31

def set(self, num):

elemIndex = self.calcElemIndex(num)

byteIndex = self.calcBitIndex(num)

elem = self.array[elemIndex]

self.array[elemIndex] = elem | (1 byteIndex)

if __name__ == ‘__main__’:

bitmap = Bitmap(90)

bitmap.set(0)

print bitmap.array

由于從第0位算起,因此 如必須儲存0,則必須把第0部位1。

清0實際操作

將某部位0,也即丟掉已儲存的數據信息。編碼以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = self.calcElemIndex(max, True)

self.array = [0 for i in range(self.size)]

def calcElemIndex(self, num, up=False):

”’up為True則為向上取整, 不然為向下取整”’

if up:

return int((num 31 – 1) / 31) #向上取整

return num / 31

def calcBitIndex(self, num):

return num % 31

def set(self, num):

elemIndex = self.calcElemIndex(num)

byteIndex = self.calcBitIndex(num)

elem = self.array[elemIndex]

self.array[elemIndex] = elem | (1 byteIndex)

def clean(self, i):

elemIndex = self.calcElemIndex(i)

byteIndex = self.calcBitIndex(i)

elem = self.array[elemIndex]

self.array[elemIndex] = elem (~(1 byteIndex))

if __name__ == ‘__main__’:

bitmap = Bitmap(87)

bitmap.set(0)

bitmap.set(34)

print bitmap.array

bitmap.clean(0)

print bitmap.array

bitmap.clean(34)

print bitmap.array

清0和置1是互反實際操作。

檢測一位是不是為1

分辨一位是不是為1是為了更好地取下以前所儲存的數據信息。編碼以下:

編碼以下:

#!/usr/bin/env python

#coding: utf8

class Bitmap(object):

def __init__(self, max):

self.size = self.calcElemIndex(max, True)

self.array = [0 for i in range(self.size)]

def calcElemIndex(self, num, up=False):

”’up為True則為向上取整, 不然為向下取整”’

if up:

return int((num 31 – 1) / 31) #向上取整

return num / 31

def calcBitIndex(self, num):

return num % 31

def set(self, num):

elemIndex = self.calcElemIndex(num)

byteIndex = self.calcBitIndex(num)

elem = self.array[elemIndex]

self.array[elemIndex] = elem | (1 byteIndex)

def clean(self, i):

elemIndex = self.calcElemIndex(i)

byteIndex = self.calcBitIndex(i)

elem = self.array[elemIndex]

self.array[elemIndex] = elem (~(1 byteIndex))

def test(self, i):

elemIndex = self.calcElemIndex(i)

byteIndex = self.calcBitIndex(i)

if self.array[elemIndex] (1 byteIndex):

return True

return False文章內容來源于:www.seo-7.comwww.sEo-6.comhttp://www.seo-6.com/seoyh/seojichurm/118357.html

(編輯:部分內容來互聯網)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/371885.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/371885.shtml
英文地址,請注明出處:http://en.pswp.cn/news/371885.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MVC如何使用開源分頁插件shenniu.pager.js

最近比較忙,前期忙公司手機端接口項目,各種開發調試發布現在幾乎上線無問題了;雖然公司項目忙不過在期間抽空做了兩件個人覺得有意義的事情,一者使用aspnetcore開發了個人線上項目(要說線上其實只能ip訪問,…

四. 基于環視Camera的BEV感知算法-PETR

目錄 前言0. 簡述1. 算法動機&開創性思路2. 主體結構3. 損失函數4. 性能對比5. PETRv2總結下載鏈接參考 前言 自動駕駛之心推出的《國內首個BVE感知全棧系列學習教程》,鏈接。記錄下個人學習筆記,僅供自己參考 本次課程我們來學習下課程第四章——基…

Java EE 6 VS Spring 3:Java EE已經殺死了Spring? 沒門!

介紹 幾天前,我在聽Java Spotlight Podcast的插曲85 。 在這次演講中, Bert Ertman和Paul Bakker討論了從Spring遷移到Java EE。 基本上,在他們的介紹中,他們說,如今,選擇Spring而不是Java EE是沒有意義的。…

usb檢測串口是哪個角_怎樣測試串口和串口線是否正常

一步:把串口線或者USB轉串口線插到計算機上。二步:打開串口調試助手接著選擇串口,串口線和 USB 轉串口的端口號查看路徑:電腦上--右鍵--屬性--硬件--設備管理器-端口(COM 和LPT),點開端口前面的號查看即可。注釋:1、US…

NodeJS常用模塊介紹

收集了NodeJS開發中常用的一些模塊。MVC框架 - Express Express 是輕量靈活的Nodejs Web應用框架,它可以快速地搭建網站。Express框架建立在Nodejs內置的Http模塊上,并對Http模塊再包裝,從而實際Web請求處理的 功能。它支持多種前端模板&…

Java泛型面試問題

Java面試中的通用面試問題在相當長的時間內在Java 5周圍越來越普遍,許多應用程序都轉移到Java 5上,并且幾乎所有新的Java開發都發生在Tiger(Java 5的代號)上。 泛型和Java 5功能(例如Enum)的重要性&#xf…

隱層元素閃一下_太陽一直依靠什么元素在燃燒,地球上的重元素又是怎么來的?...

本文基于回答網友一個這樣的問題:太陽目前氫核聚變是氦碳氧穩定燃燒地球上的鐵鎳重元素哪里來的?可以說,這是一個毫無邏輯亂七八糟的問題,但既然邀請回答,就從中挑出幾個稍顯合理的問題說明一下。太陽核心每時每刻都在…

基于Token的WEB后臺認證機制

基于Token的WEB后臺認證機制 幾種常用的認證機制 HTTP Basic Auth HTTP Basic Auth簡單點說明就是每次請求API時都提供用戶的username和password,簡言之,Basic Auth是配合RESTful API 使用的最簡單的認證方式,只需提供用戶名密碼即可&#xf…

JSF基于事件的溝通:過時的方法

用JSF編寫的Web應用程序由相互交互的bean組成。 在開發Web應用程序時,bean之間的通信是主要的設計模式之一。 有時,一個bean需要向其他bean發送事件,以通知它們某些更改或其他任何更改。 我們通常可以將托管bean或Spring bean注入另一個bean的…

mysql調優 基礎

MySQL調優可以從幾個方面來做:1. 架構層:做從庫,實現讀寫分離;2.系統層次:增加內存;給磁盤做raid0或者raid5以增加磁盤的讀寫速度;可以重新掛載磁盤,并加上noatime參數,這…

saltstack

第一:安裝前準備: 聲明我用的是ubuntu 16.04的系統 1.修改主機名,并保證兩臺機器可以互相ping同主機名 ip1 master_hostname ip2 slave_hostname 第二:安裝 服務器安裝 yum install salt-master -y客戶端安裝 yum install salt…

ios 百度地圖指定區域_獲取百度地圖可視區域范圍的數據

有個業務場景,需要根據獲取到的地圖區域顯示,根據相應的經緯度反查 左側區域的會議室。思路:1.得到百度地圖可視區域--可視區域的中心點2.可視區域的四個角的其中兩個(東北角西南角)http://lbsyun.baidu.com/cms/jsapi/reference/jsapi_refer…

使用WS-Trust / STS采樣器擴展JMeter

JMeter沒有對WS-Security或WS-Trust的任何內置支持,這使我為JMeter開發了此STS Sampler –可以在負載測試STS時使任何人的生活變得更好。 首先,您需要擁有Apache JMeter發行版。 我正在使用v2.7。 然后,您可以從此處下載sts.sampler.zip –解…

分享一個使用閉包對一個對象繼承方式

function Person(name,age){this.name name;this.age age; }//定義一個new函數 繼承了對Person的繼承 function New(obj){return function(){var o {"__proto__":obj.proto};obj.apply(o,arguments);}return obj; }var n new New(Person)("對象繼承了person…

vue怎么改logo_vue全家桶項目構建教程

前言vue是現階段很流行的前端框架,很多人通過vue官方文檔的學習,對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發現不知道改怎么更好的管理自己的項目,如何去引入一些框架以及vue全家桶其他框架的使用&a…

EclipseLink MOXy作為JAXB提供者

EclipseLink MOXy是JAXB提供程序,并且是內置在JDK中的默認JAXB提供程序的引人注目的替代品。 首先是一個簡單的測試,將Java對象編組為XML: 這是模型: XmlRootElement(nameMemberDetailsRequest, namespacehttp://bk.org/members…

monkeyrunner多點觸摸

思路是:在屏幕上某個位置按著不放:device.touch(x,y,md.DOWN) 然后再做一個滑動的操作:device.drap((x1,y1),(x2,y2),0.2,10) 然后再松開按鍵:device.touch(x,y,md.UP) #codeing:utf-8 from com.android.monkeyrunner import Monk…

雅虎前端優化的35條軍規

閱讀目錄 內容部分css部分js部分javascript, css 圖片 cookie移動端 服務器摘要:無論是在工作中,還是在面試中,web前端性能的優化都是很重要的,那么我們進行優化需要從哪些方面入手呢?可以遵循雅虎的前端優化34條軍規&…

stm32 內部sram大小_在SRAM、FLASH中調試代碼的配置方法(附詳細步驟)

聊天界面發送嵌入式大雜燴獲取1TB大雜燴資料包STM32的FLASH擦寫次數有限(大概為1萬次),所以為了延長FLASH的使用時間,我們平時調試時可以選擇在SRAM中進行硬件調試。除此之外,SRAM 存儲器的寫入速度比在內部 FLASH 中要快得多,所以…

Spring Profile模式示例

最近,我們介紹了Spring Profiles的概念。 此概念是針對不同部署環境的輕松配置區分符。 直接的用例(已提出)是對相關類進行注釋,以便Spring根據活動的配置文件加載適當的類。 但是,這種方法可能并不總是適用于常見的…