散列表是一種高效的資料結構,它透過將資料映射到固定大小的數組(「桶」)來實現快速查找,每個桶包含具有相同鍵的資料。 PHP 中的散列表使用雜湊函數,將任意大小的資料轉換為固定長度的整數,該整數用於計算散列表中資料的桶。
PHP 資料結構:散列表的實作原理,探索資料快速尋找的奧秘
##簡介
散列表(哈希表)是一種高效的資料結構,用於快速查找資料。它透過將資料映射到一個固定大小的數組,即“桶”,來實現快速查找。每個桶都包含具有相同鍵的資料。實作原理
PHP 中散列表的實作原理是基於雜湊函數。哈希函數將任意大小的資料轉換為固定長度的整數。這個整數用於計算資料在散列表中插入的桶。
程式碼實作:自訂散列表
以下是PHP 中實作散列表的範例程式碼:class HashTable { private $buckets = []; private $size = 0; public function __construct($size) { $this->size = $size; } public function hash(string $key): int { return crc32($key) % $this->size; } public function set(string $key, $value): void { $index = $this->hash($key); $this->buckets[$index][$key] = $value; } public function get(string $key): mixed { $index = $this->hash($key); if (isset($this->buckets[$index][$key])) { return $this->buckets[$index][$key]; } else { return null; } } }
實戰案例:按年齡分組員工
假設我們有一個包含員工年齡的數組,我們希望將員工按年齡分組。我們可以使用散列表來快速尋找相同年齡的員工。$ages = [25, 30, 28, 35, 32, 25, 30]; $hashTable = new HashTable(count($ages)); foreach ($ages as $age) { $hashTable->set($age, []); } foreach ($ages as $age) { $hashTable->get($age)[] = $age; } var_dump($hashTable->buckets);
輸出結果:
array( 25 => array(25, 25), 30 => array(30, 30), 28 => array(28), 35 => array(35), 32 => array(32) )
以上是PHP資料結構:散列表的實作原理,探究資料快速找到的奧秘的詳細內容。更多資訊請關注PHP中文網其他相關文章!