PHP实现一个hash表(拉链法解决hash冲突)代码实例

<?php
header('Content-type:text/html;charset=utf-8');

class HashTable{
    private $buckets;
    private $size = 10;
    public function __construct()
    {
        $this->buckets = new SplFixedArray($this->size);
    }

    private function hash_func($key)
    {
        $strlen = strlen($key);
        $hash_val = 0;
        for ($i=0;$i<$strlen;$i++){
            $hash_val += ord($key[$i]);
        }
        return $hash_val%$this->size;
    }

    public function insert($key,$val)
    {
        $index = $this->hash_func($key);
        if(isset($this->buckets[$index])){
            $new_code = new HashNode($key,$val,$this->buckets[$index]);
        }else{
            $new_code = new HashNode($key,$val,null);
        }
        $this->buckets[$index] = $new_code;
    }

    public function find($key)
    {
        $index = $this->hash_func($key);
        $current = $this->buckets[$index];
        while (isset($current)) {
            if ($current->key == $key){
                return $current->value;
            }
            $current = $current->next_node;
        }
        return null;
    }
}

class HashNode{
    public $key;
    public $value;
    public $next_node;
    public function __construct($key,$value,$next_node=null)
    {
        $this->key = $key;
        $this->value = $value;
        $this->next_node = $next_node;
    }


}

$hash = new HashTable();
$hash->insert('value1','A');
$hash->insert('value12','B');
//echo $hash->find('value1');
//echo $hash->find('value2');
echo $hash->find('value1');
echo $hash->find('value12');

记录一下实例,有兴趣的可以一起研究下。。。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luyaran

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值