午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

Python查找算法之分塊查找算法的實現(xiàn)

瀏覽:12日期:2022-06-23 08:59:52
一、分塊查找算法

分塊查找是二分法查找和順序查找的改進方法,分塊查找要求索引表是有序的,對塊內(nèi)結點沒有排序要求,塊內(nèi)結點可以是有序的也可以是無序的。

分塊查找就是把一個大的線性表分解成若干塊,每塊中的節(jié)點可以任意存放,但塊與塊之間必須排序。與此同時,還要建立一個索引表,把每塊中的最大值作為索引表的索引值,此索引表需要按塊的順序存放到一個輔助數(shù)組中。查找時,首先在索引表中進行查找,確定要找的結點所在的塊。由于索引表是排序的,因此,對索引表的查找可以采用順序查找或二分查找;然后,在相應的塊中采用順序查找,即可找到對應的結點。

例如,有這樣一列數(shù)據(jù):23、43、56、78、97、100、120、135、147、150。如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

想要查找的數(shù)據(jù)是 150,使用分塊查找法步驟如下:

步驟1:將上圖所示的數(shù)據(jù)進行分塊,按照每塊長度為 4 進行分塊,分塊情況如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

說明:每塊的長度是任意指定的,博主在這里用的長度為4,讀者可以根據(jù)自己的需要指定每塊長度。

步驟2:選取各塊中的最大關鍵字構成一個索引表,即選取上圖所示的各塊的最大值,第一塊最大的值是 78,第二塊最大的值是 135,第三塊最大值是 155,形成的索引表如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

步驟3:用順序查找或者二分查找判斷想要查找數(shù)據(jù) 150 在上圖所示的索引表中的哪塊內(nèi)容中,這里博主用的是二分查找法,即先取中間值 135 與 150 比較,如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

步驟4:結果是中間位置的數(shù)據(jù) 135 比目標數(shù)據(jù) 150 小,因此目標數(shù)據(jù)在 135 的下一塊內(nèi)。將數(shù)據(jù)定位在第 3 塊內(nèi),此時將第 3 塊內(nèi)的數(shù)據(jù)取出,進行順序比較,如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

步驟5:通過順序查找第 3 塊的內(nèi)容,終于在第 9 個位置找到目標數(shù),此時分塊查找結束。

總結:至此,分塊查找算法已經(jīng)講解完畢。通過和二分查找法和順序查找法對比來看,分塊查找的速度雖然不如二分查找算法,但比順序查找算法快得多。當數(shù)據(jù)很多且塊數(shù)很大時,對索引表可以采用二分查找,這樣能夠進一步提高查找的速度。

二、實例:實現(xiàn)分塊查找算法

具體代碼如下:

def search(data, key): # 用二分查找 想要查找的數(shù)據(jù)在哪塊內(nèi) length = len(data) # 數(shù)據(jù)列表長度 first = 0 # 第一位數(shù)位置 last = length - 1 # 最后一個數(shù)據(jù)位置 print(f'長度:{length} 分塊的數(shù)據(jù)是:{data}') # 輸出分塊情況 while first <= last:mid = (last + first) // 2 # 取中間位置if data[mid] > key: # 中間數(shù)據(jù)大于想要查的數(shù)據(jù) last = mid - 1 # 將last的位置移到中間位置的前一位elif data[mid] < key: # 中間數(shù)據(jù)小于想要查的數(shù)據(jù) first = mid + 1 # 將first的位置移到中間位置的后一位else: return mid # 返回中間位置 return False# 分塊查找def block(data, count, key): # 分塊查找數(shù)據(jù),data是列表,count是每塊的長度,key是想要查找的數(shù)據(jù) length = len(data) # 表示數(shù)據(jù)列表的長度 block_length = length // count # 一共分的幾塊 if count * block_length != length: # 每塊長度乘以分塊總數(shù)不等于數(shù)據(jù)總長度block_length += 1 # 塊數(shù)加1 print('一共分', block_length, '塊') # 塊的多少 print('分塊情況如下:') for block_i in range(block_length): # 遍歷每塊數(shù)據(jù)block_data = [] # 每塊數(shù)據(jù)初始化for i in range(count): # 遍歷每塊數(shù)據(jù)的位置 if block_i * count + i >= length: # 每塊長度要與數(shù)據(jù)長度比較,一旦大于數(shù)據(jù)長度break # 就退出循環(huán) block_data.append(data[block_i * count + i]) # 每塊長度要累加上一塊的長度result = search(block_data, key) # 調(diào)用二分查找的值if result != False: # 查找的結果不為False return block_i * count + result # 就返回塊中的索引位置 return Falsedata = [23, 43, 56, 78, 97, 100, 120, 135, 147, 150, 155] # 數(shù)據(jù)列表result = block(data, 4, 150) # 第二個參數(shù)是塊的長度,最后一個參數(shù)是要查找的元素print('查找的值得索引位置是:', result) # 輸出結果

運行結果如下圖所示:

Python查找算法之分塊查找算法的實現(xiàn)

從上面的運行結果看到,當查找 150 時,查找結果完全符合上述描述的步驟。

到此這篇關于Python查找算法之分塊查找算法的實現(xiàn)的文章就介紹到這了,更多相關Python 分塊查找算法內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 欧美色国| 美女福利在线 | 亚洲无人区码一码二码三码 | 国产精品视频久久久久 | 欧美激情一区二区视频 | 都市激情一区 | 四虎影院www | 视频在线观看91 | 久久三 | 久草视频免费在线 | 日一区二区 | 成年人黄色免费视频 | 色姑娘综合| www天天操| 免费黄网站在线观看 | 日本奶汁.哺乳xxx | 亚洲成人资源 | 亚洲在线视频网站 | 99天堂网 | 午夜影院a | av最新网址 | 天天宗合网 | 秋霞成人午夜鲁丝一区二区三区 | 五月婷婷在线播放 | 人人看人人做 | 91免费福利视频 | 日本wwwwwww | 操操操操操操 | 黄页网站在线看 | 国产在线播放一区二区三区 | 五月婷婷激情综合网 | 午夜影院免费观看 | 中文字幕精品视频 | 国产福利视频在线 | 在线视频亚洲 | 超碰亚洲 | xxxx亚洲 | 大地av | 五月婷婷激情在线 | 在线免费日韩 | 丁香婷婷激情 |