php的哈希表怎么实现

本篇内容介绍了“php的哈希表怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联是一家专业提供舒兰企业网站建设,专注与成都做网站、网站建设、HTML5、小程序制作等业务。10年已为舒兰众多企业、政府机构等服务。创新互联专业网络公司优惠进行中。

1.概念

哈希表是一种通过哈希函数,将特定的键映射到特定值的一种数据结构,它维护键和值之间一一对应关系。

2.说明

(1)哈希表是一种数据结构

(2)哈希表表示了关键码值和记录的映射关系

(3)哈希表可以加快查找速度

(4)任意哈希表,都满足有哈希函数f(key),代入任意key值都可以获取包含该key值的记录在表中的地址

3.实例

buckets = new SplFixedArray($this->size);
//SplFixedArray效率更高,也可以用一般的数组来代替
}
 
    private function hashfunc($key){
$strlen = strlen($key); //返回字符串的长度
$hashval = 0;  
for($i = 0; $i<$strlen ; $i++){
$hashval +=ord($key[$i]); //返回ASCII的值
}
return $hashval%12;    //    返回取余数后的值
}
public function insert($key,$value){
$index = $this->hashfunc($key);
if(isset($this->buckets[$index])){
$newNode = new HashNode($key,$value,$this->buckets[$index]);
}else{
$newNode = new HashNode($key,$value,null);
}
$this->buckets[$index] = $newNode;
}
public function find($key){
$index = $this->hashfunc($key);
$current = $this->buckets[$index];
echo "
"; var_dump($current); while(isset($current)){    //遍历当前链表 if($current->key==$key){    //比较当前结点关键字 return $current->value; } $current = $current->nextNode; //return $current->value; } return NULL; } }  class HashNode{ public $key;  //关键字 public $value;  //数据 public $nextNode; //HASHNODE来存储信息 public function __construct($key,$value,$nextNode = NULL){ $this->key = $key; $this->value = $value; $this->nextNode = $nextNode; } }   $ht = new HashTable();   $ht->insert('Bucket1','value1');   $ht->insert('Bucket2','value2');   $ht->insert('Bucket3','value3');   echo $ht->find('Bucket1'); ?>

“php的哈希表怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


本文标题:php的哈希表怎么实现
标题路径:http://myzitong.com/article/jdodso.html