搜索
首页 电脑/网络

PHPHash算法:Times33算法代码实例_PHP教程

全部回答

2023-03-15

0 0

    PHP Hash算法:Times33算法代码实例这篇文章主要介绍了PHP Hash算法:Times33算法代码实例,本文直接给出实现代码,需要的朋友可以参考下最近看书,里面提到了一些Hash算法。
  比较有印象的是Times33,当时理解不是很透测,今天写了段程序来验证了一下。  先上代码:代码如下:/*** CRC32 Hash function* @param $str* @return int*/function hash32($str){return crc32($str) >>16 & 0x7FFFFFFF;}/*** Times33 Hash function* @param $str* @return int*/function hash33($str){$hash = 0;for($i=0; $i$hash += 33 * $hash + ord($str{$i});}return $hash & 0x7FFFFFFF;}$n = 10;// Test Case 1$stat = array();for($i=0; $i$str = substr(md5(microtime(true)), 0, 8);$p = hash32($str) % $n;if(isset($stat[$p])){$stat[$p]++;}else{$stat[$p] = 1;}}print_r($stat);// Test Case 2$stat = array();for($i=0; $i$str = substr(md5(microtime(true)), 0, 8);$p = hash33($str) % $n;if(isset($stat[$p])){$stat[$p]++;}else{$stat[$p] = 1;}}print_r($stat);以上有两个测试用例。
    第一个,用CRC32的方法;第二个是Times33的算法实现。效果:结果分布,两种算法不相上下(估计是数据源的问题,md5只有0-f)。也有文章说CRC32的分布更均匀(参考链接:)但耗费时间,CRC32比Times33快将近一倍。
  为什么是33?即是素数(质数),也是奇数。  除了33,还有131, 1313, 5381等。PHP内置的Hash函数用的是5381,在“鸟哥”的一篇博文中也有提到。
  http://www。bkjia。com/PHPjc/1000082。htmlwww。bkjia。comtruehttp://www。  bkjia。com/PHPjc/1000082。
  htmlTechArticlePHP Hash算法:Times33算法代码实例 这篇文章主要介绍了PHP Hash算法:Times33算法代码实例,本文直接给出实现代码,需要的朋友可以参考下 最近看。
  

类似问题换一批

热点推荐

热度TOP

相关推荐
加载中...

热点搜索 换一换

电脑/网络
电脑/网络
程序设计
电脑装机
操作系统/系统故障
硬件
笔记本电脑
百度
互联网
反病毒
软件
举报
举报原因(必选):
取消确定举报