Search
 
SCRIPT & CODE EXAMPLE
 

PHP

what is the hashmap like in php

class IEqualityComparer {
    public function equals($x, $y) {
        throw new Exception("Not implemented!");
    }
    public function getHashCode($obj) {
        throw new Exception("Not implemented!");
    }
}

class HashMap {
    private $map = array();
    private $comparer;

    public function __construct(IEqualityComparer $keyComparer) {
        $this->comparer = $keyComparer;
    }

    public function has($key) {
        $hash = $this->comparer->getHashCode($key);

        if (!isset($this->map[$hash])) {
            return false;
        }

        foreach ($this->map[$hash] as $item) {
            if ($this->comparer->equals($item['key'], $key)) {
                return true;
            }
        }

        return false;
    }

    public function get($key) {
        $hash = $this->comparer->getHashCode($key);

        if (!isset($this->map[$hash])) {
            return false;
        }

        foreach ($this->map[$hash] as $item) {
            if ($this->comparer->equals($item['key'], $key)) {
                return $item['value'];
            }
        }

        return false;
    }

    public function del($key) {
        $hash = $this->comparer->getHashCode($key);

        if (!isset($this->map[$hash])) {
            return false;
        }

        foreach ($this->map[$hash] as $index => $item) {
            if ($this->comparer->equals($item['key'], $key)) {
                unset($this->map[$hash][$index]);
                if (count($this->map[$hash]) == 0)
                    unset($this->map[$hash]);

                return true;
            }
        }

        return false;
    }

    public function put($key, $value) {
        $hash = $this->comparer->getHashCode($key);

        if (!isset($this->map[$hash])) {
            $this->map[$hash] = array();
        }

        $newItem = array('key' => $key, 'value' => $value);        

        foreach ($this->map[$hash] as $index => $item) {
            if ($this->comparer->equals($item['key'], $key)) {
                $this->map[$hash][$index] = $newItem;
                return;
            }
        }

        $this->map[$hash][] = $newItem;
    }
}
Comment

PREVIOUS NEXT
Code Example
Php :: laravel read file from tmp 
Php :: Server Requirements in laraavel 9 
Php :: laravel createmany example 
Php :: echo ternary php 
Php :: wpdb num_rows 
Php :: page break in dompdf 
Php :: php copy image from remote to local server 
Php :: query php 
Php :: php check for null 
Php :: define in php 
Php :: return view in laravel controller 
Php :: get database columns laravel 
Php :: PHP Forms - Required Fields 
Php :: window.location javascript php 
Php :: php global variable function 
Php :: make table in laravel 
Php :: composer update php mbstring.so missing 
Php :: php now 
Php :: php to list files 
Php :: ile_put_contents(/opt/bitnami/apache2/htdocs/bootstrap/cache/services.php): failed to open stream: Permission denied 
Php :: laravel assets 
Php :: creating thumbnail in codeigniter 
Php :: php round up 
Php :: get page thumbnail id wordpress 
Php :: php regex match numbers only 
Php :: update many laravel 
Php :: install php extensions for magento 2 
Php :: rand string php 
Php :: jquery serialize php decode 
Php :: pdo prepare 
ADD CONTENT
Topic
Content
Source link
Name
2+9 =