日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Python查找算法之分塊查找算法的實現

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

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

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

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

Python查找算法之分塊查找算法的實現

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

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

Python查找算法之分塊查找算法的實現

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

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

Python查找算法之分塊查找算法的實現

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

Python查找算法之分塊查找算法的實現

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

Python查找算法之分塊查找算法的實現

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

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

二、實例:實現分塊查找算法

具體代碼如下:

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

運行結果如下圖所示:

Python查找算法之分塊查找算法的實現

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

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

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费视频久久| 日韩一区欧美| 日韩欧美精品一区| av高清不卡| 成人欧美一区二区三区的电影| 亚洲最新av| 日韩国产91| 国产精品久久久久久久久免费高清 | 国产亚洲永久域名| 亚洲福利精品| 久久aⅴ国产紧身牛仔裤| 男女男精品视频网| 日韩精品水蜜桃| 99国产精品| 亚洲一区二区免费在线观看| 日本欧美一区| 国产一区二区三区视频在线| 日韩大片在线观看| 蜜桃久久av| 久久精品国产精品亚洲毛片| 亚洲精品.com| 日本一区中文字幕| 日本一二区不卡| 在线观看免费一区二区| 日韩欧美中文字幕在线视频| 欧美交a欧美精品喷水| 群体交乱之放荡娇妻一区二区| 久久久噜噜噜| 人人爽香蕉精品| 国产一区精品福利| 欧美 日韩 国产精品免费观看| 亚洲一区二区三区四区电影| 亚洲综合电影| 国产日韩亚洲欧美精品| 欧美日韩国产传媒| 欧美精品二区| 中文精品电影| 婷婷六月综合| 午夜精品成人av| 国产精品日本一区二区三区在线 | 日韩欧美久久| 日韩88av| 国产乱人伦丫前精品视频| 欧美日韩中文一区二区| 国产精品久久久网站| 亚洲精品无播放器在线播放| 免费在线小视频| 久久99蜜桃| 国产精品亚洲四区在线观看| 日韩中文字幕区一区有砖一区| 久久久久亚洲| 色天使综合视频| 91免费精品| 成年男女免费视频网站不卡| 国产精品v亚洲精品v日韩精品| 亚洲精品美女91| 美日韩精品视频| 色88888久久久久久影院| 美女视频免费精品| 欧美日韩午夜电影网| 日韩精品免费观看视频| 中文字幕视频精品一区二区三区| 欧美aa一级| 99精品视频精品精品视频| 黄在线观看免费网站ktv| 日本久久综合| 久久久人人人| 国产精品丝袜xxxxxxx| 另类av一区二区| 综合欧美亚洲| 国产一级成人av| 婷婷五月色综合香五月| 日本三级亚洲精品| 亚洲精品乱码| 久久激情av| 98精品久久久久久久| 久久国产亚洲精品| 首页亚洲欧美制服丝腿| 日韩精品久久久久久久软件91| 欧美精品国产白浆久久久久| 牛牛精品成人免费视频| 欧美亚洲日本精品| 国产亚洲午夜| 国产精品嫩模av在线| 999国产精品永久免费视频app| 久久精品91| 免费在线看一区| 日本不卡不码高清免费观看 | 91精品国产自产在线丝袜啪| 国产精品一级在线观看| 久久精品亚洲人成影院| 性一交一乱一区二区洋洋av| 国产精品综合| 久久高清国产| 久久uomeier| 亚洲一级大片| 日韩美女一区二区三区在线观看| 国产在线欧美| 久久激情av| 亚洲精品在线观看91| 久久久91麻豆精品国产一区| 中文欧美日韩| 久久天堂影院| 99在线精品视频在线观看| 老鸭窝一区二区久久精品| 亚洲精品电影| 亚洲精品成人图区| 久久国产婷婷国产香蕉| 免费成人av在线播放| 久久久久99| 伊人网在线播放| 国产福利一区二区三区在线播放| 亚洲免费影院| 免费不卡中文字幕在线| 国产成人免费精品| 国产乱子精品一区二区在线观看 | 国产精品久久久久久久久久白浆| 激情久久五月| 精品国产网站| 综合一区二区三区| 美女毛片一区二区三区四区 | 国产亚洲字幕| 国产精品任我爽爆在线播放| 日韩二区在线观看| 日韩欧美高清一区二区三区| 免费精品视频| 国产视频亚洲| 热久久久久久久| 免费日韩av| 国产免费成人| 日韩中文字幕区一区有砖一区| 先锋影音国产一区| 亚洲精品看片| 日韩高清电影一区| 国产欧美69| 国产一级成人av| 国产日韩欧美高清免费| 国产欧美二区| 捆绑调教日本一区二区三区| 亚洲国产影院| 亚洲人成亚洲精品| 国产亚洲久久| 在线人成日本视频| 日韩一区二区免费看| 亚洲欧美成人综合| 日韩av字幕| 黄色在线观看www| 亚洲欧美日本国产专区一区| 亚洲精品国产精品粉嫩| 国产福利亚洲| 欧美特黄视频| 国产精品最新| 久久亚洲风情| 国产精品66| 国产一区丝袜| 亚洲一区二区三区四区五区午夜| 天堂精品久久久久| 国内自拍视频一区二区三区| 香蕉精品视频在线观看| 爽爽淫人综合网网站| 日产精品一区二区| 亚洲精品麻豆| 在线精品视频在线观看高清| 国产美女视频一区二区| 午夜久久美女| 国产乱码午夜在线视频| 爽好久久久欧美精品| 日韩久久视频| 欧美国产不卡| 婷婷综合电影| 99国产精品久久久久久久| 国产一区二区三区四区大秀| 免费成人在线视频观看| 国产精品最新| 国产高清日韩| 日本a口亚洲| 丝袜美腿亚洲色图| 久久中文字幕二区| 国产成人免费精品| 国产精品久久乐| 日本少妇一区二区| 丝袜美腿成人在线| 男女精品网站| 日韩视频中文| 亚洲国产专区校园欧美| 欧美成人a交片免费看| 久久中文在线| 久久成人av| 欧美激情福利| 国产精品美女午夜爽爽| 国产日韩三级| 久久中文在线| 成人在线免费观看网站| 成人午夜在线| 一本综合精品| 亚洲91网站| 欧美日韩夜夜| 久久99影视| 中文另类视频| 先锋影音国产一区|