首頁 >後端開發 >php教程 >PHP資料結構:散列表的實作原理,探究資料快速找到的奧秘

PHP資料結構:散列表的實作原理,探究資料快速找到的奧秘

PHPz
PHPz原創
2024-06-03 18:32:01834瀏覽

散列表是一種高效的資料結構,它透過將資料映射到固定大小的數組(「桶」)來實現快速查找,每個桶包含具有相同鍵的資料。 PHP 中的散列表使用雜湊函數,將任意大小的資料轉換為固定長度的整數,該整數用於計算散列表中資料的桶。

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn