91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP Hash算法中的Times33算法實例應用

發布時間:2021-09-06 14:58:10 來源:億速云 閱讀:101 作者:chen 欄目:開發技術

這篇文章主要講解了“PHP Hash算法中的Times33算法實例應用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“PHP Hash算法中的Times33算法實例應用”吧!

最近看書,里面提到了一些Hash算法。比較有印象的是Times33,當時理解不是很透測,今天寫了段程序來驗證了一下。
先上代碼:

復制代碼 代碼如下:


<?php

/**
 * CRC32 Hash function
 * @param $str
 * @return int
 */
function hash42($str)
{
    return crc32($str) >> 16 & 0x7FFFFFFF;
}

/**
 * Times33 Hash function
 * @param $str
 * @return int
 */
function hash43($str)
{
    $hash = 0;
    for($i=0; $i<strlen($str); $i++) {
        $hash += 33 * $hash + ord($str{$i});
    }
    return $hash & 0x7FFFFFFF;
}


$n = 10;

// Test Case 1
$stat = array();
for($i=0; $i<10000; $i++){
    $str = substr(md5(microtime(true)), 0, 8);
    $p = hash42($str) % $n;
    if(isset($stat[$p])){
        $stat[$p]++;
    }else{
        $stat[$p] = 1;
    }
}
print_r($stat);

// Test Case 2
$stat = array();
for($i=0; $i<10000; $i++){
    $str = substr(md5(microtime(true)), 0, 8);
    $p = hash43($str) % $n;
    if(isset($stat[$p])){
        $stat[$p]++;
    }else{
        $stat[$p] = 1;
    }
}
print_r($stat);

以上有兩個測試用例。第一個,用CRC32的方法;第二個是Times33的算法實現。

效果:

結果分布,兩種算法不相上下
但耗費時間,CRC32比Times33快將近一倍。

感謝各位的閱讀,以上就是“PHP Hash算法中的Times33算法實例應用”的內容了,經過本文的學習后,相信大家對PHP Hash算法中的Times33算法實例應用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

仙桃市| 永嘉县| 绍兴县| 手机| 砀山县| 南木林县| 陈巴尔虎旗| 湖南省| 玉环县| 泰兴市| 容城县| 和顺县| 哈密市| 安顺市| 新昌县| 西和县| 宜春市| 新闻| 大悟县| 贵溪市| 通州区| 辽源市| 晋宁县| 涞源县| 上栗县| 荥经县| 榆林市| 新河县| 绥中县| 七台河市| 朝阳市| 霍城县| 谢通门县| 衡东县| 化德县| 葵青区| 九江市| 永胜县| 安庆市| 师宗县| 通州区|