Home > Backend Development > PHP Tutorial > PHP data structure: Implementation principle of hash table, explore the secret of fast data search

PHP data structure: Implementation principle of hash table, explore the secret of fast data search

PHPz
Release: 2024-06-03 18:32:01
Original
866 people have browsed it

A hash table is an efficient data structure that enables fast lookups by mapping data into fixed-size arrays ("buckets"), each bucket containing data with the same key. Hash tables in PHP use a hash function to convert data of any size into a fixed-length integer, which is used to calculate the buckets of the data in the hash table.

PHP data structure: Implementation principle of hash table, explore the secret of fast data search

PHP data structure: implementation principle of hash table, exploring the secret of fast data search

Introduction

Hash table (hash table) is an efficient data structure used to find data quickly. It achieves fast lookups by mapping data into a fixed-size array, a "bucket." Each bucket contains data with the same key.

Implementation principle

The implementation principle of hash table in PHP is based on Hash function. A hash function converts data of any size into a fixed-length integer. This integer is used to calculate the bucket into which the data is inserted in the hash table.

Code implementation: Custom hash table

The following is a sample code to implement a hash table in 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;
        }
    }
}
Copy after login

Actual case: Press Group employees by age

Suppose we have an array containing the ages of employees and we want to group employees by age. We can use a hash table to quickly find employees with the same age.

$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);
Copy after login

Output result:

array(
    25 => array(25, 25),
    30 => array(30, 30),
    28 => array(28),
    35 => array(35),
    32 => array(32)
)
Copy after login

The above is the detailed content of PHP data structure: Implementation principle of hash table, explore the secret of fast data search. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template