哈希表是一種重要的資料結構,在電腦科學中應用廣泛。它可以快速地在大量資料中尋找、插入或刪除一個特定的元素。用Python實作雜湊表,不僅可以深入理解雜湊表的內部工作機制,也可以增強自己的程式設計能力。在本文中,我們將詳細介紹如何用Python實作雜湊表。
- 什麼是哈希表
哈希表又被稱為散列表,它是一種 key-value 儲存方法。它透過將 key 映射到 value 的一個索引位置來存取資料。它的基本操作包括插入、刪除和查找。
雜湊表的核心思想是使用雜湊函數將每個 key 對應到固定大小的表中。雜湊函數是一種將任意長度的輸入訊息轉換為固定長度輸出的函數。常見的雜湊函數有MD5、SHA1、SHA256等。
- 實作雜湊表
我們用Python實作一個簡單的雜湊表,包括雜湊表的基本操作,如插入、刪除和查找等。
先定義一個Node類,表示哈希表的節點。每個節點包含一個key和一個value。
class Node: def __init__(self, key, val): self.key = key self.val = val self.next = None
接下來定義一個HashTable類,我們用Python的list實作底層資料結構。插入key-value對時,我們需要根據key計算哈希值,並將key-value對儲存在哈希表中對應的位置。
class HashTable: def __init__(self): self.size = 100 self.table = [None] * self.size def hash_func(self, key): return sum([ord(c) for c in key]) % self.size def insert(self, key, value): hash_value = self.hash_func(key) if self.table[hash_value] is None: self.table[hash_value] = Node(key, value) else: cur = self.table[hash_value] while cur.next is not None: cur = cur.next cur.next = Node(key, value) def search(self, key): hash_value = self.hash_func(key) if self.table[hash_value] is None: return None else: cur = self.table[hash_value] while cur is not None: if cur.key == key: return cur.val else: cur = cur.next return None def delete(self, key): hash_value = self.hash_func(key) if self.table[hash_value] is None: return elif self.table[hash_value].key == key: self.table[hash_value] = self.table[hash_value].next else: cur = self.table[hash_value] while cur.next is not None: if cur.next.key == key: cur.next = cur.next.next return else: cur = cur.next
在上述程式碼中,hash_func方法根據key計算哈希值,insert方法將key-value對插入到哈希表中對應的位置上,search方法根據key查找value,delete方法根據key刪除對應的key-value對。
- 測試雜湊表
接下來我們測試上述實作的雜湊表。
ht = HashTable() ht.insert('apple', 2.5) ht.insert('banana', 1.3) ht.insert('orange', 0.7) print(ht.search('apple')) # 2.5 print(ht.search('banana')) # 1.3 print(ht.search('orange')) # 0.7 print(ht.search('lemon')) # None ht.delete('apple') print(ht.search('apple')) # None
上述程式碼中,我們建立了一個HashTable物件ht,並將三個key-value對插入ht。然後,我們透過search方法找出key為'apple'、'banana'和'orange'的value,並刪除一個key為'apple'的key-value對。最後,我們再查找key為'apple'的value,應該回傳None。
- 總結
本文介紹如何用Python實作雜湊表。我們定義了一個Node類別表示哈希表的一個節點,再定義了一個HashTable類別表示哈希表,並實作了哈希表的基本操作,例如插入、刪除和查找等。透過實作雜湊表,我們可以深入理解雜湊表的內部工作機制,並增強自己的程式設計能力。
以上是如何用Python實作雜湊表的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python和C 各有優勢,選擇應基於項目需求。 1)Python適合快速開發和數據處理,因其簡潔語法和動態類型。 2)C 適用於高性能和系統編程,因其靜態類型和手動內存管理。

選擇Python還是C 取決於項目需求:1)如果需要快速開發、數據處理和原型設計,選擇Python;2)如果需要高性能、低延遲和接近硬件的控制,選擇C 。

通過每天投入2小時的Python學習,可以有效提升編程技能。 1.學習新知識:閱讀文檔或觀看教程。 2.實踐:編寫代碼和完成練習。 3.複習:鞏固所學內容。 4.項目實踐:應用所學於實際項目中。這樣的結構化學習計劃能幫助你係統掌握Python並實現職業目標。

在兩小時內高效學習Python的方法包括:1.回顧基礎知識,確保熟悉Python的安裝和基本語法;2.理解Python的核心概念,如變量、列表、函數等;3.通過使用示例掌握基本和高級用法;4.學習常見錯誤與調試技巧;5.應用性能優化與最佳實踐,如使用列表推導式和遵循PEP8風格指南。

Python適合初學者和數據科學,C 適用於系統編程和遊戲開發。 1.Python簡潔易用,適用於數據科學和Web開發。 2.C 提供高性能和控制力,適用於遊戲開發和系統編程。選擇應基於項目需求和個人興趣。

Python更適合數據科學和快速開發,C 更適合高性能和系統編程。 1.Python語法簡潔,易於學習,適用於數據處理和科學計算。 2.C 語法複雜,但性能優越,常用於遊戲開發和系統編程。

每天投入兩小時學習Python是可行的。 1.學習新知識:用一小時學習新概念,如列表和字典。 2.實踐和練習:用一小時進行編程練習,如編寫小程序。通過合理規劃和堅持不懈,你可以在短時間內掌握Python的核心概念。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

禪工作室 13.0.1
強大的PHP整合開發環境