首頁 > 後端開發 > PHP問題 > php如何取隨機數不重複?

php如何取隨機數不重複?

coldplay.xixi
發布: 2023-03-03 06:44:01
原創
3848 人瀏覽過

php取隨機數不重複的方法:1、使用【rand(min,max)】函數產生隨機數;2、使用【array_unique(arr)】對產生的陣列進行去重;3、利用索引快速的產生不重複的隨機數。

php如何取隨機數不重複?

php取隨機數不重複的方法:

首先想到的是rand(min, max)函數產生隨機數,實際上使用mt_rand(min,max)能更加迅速的產生隨機數。

其次使用array_unique(arr)對產生的陣列進行去重,實際上使用array_flip(array_flip(arr))能更加快速的進行去重。

了解以上兩點我們便可以寫一個稍微優化過的函數:

/**
 * 生成指定长度不重复的字符串.
 *
 * @param integer $min 最小值.
 * @param integer $max 最大值.
 * @param integer $len 生成数组长度.
 *
 * @return array
 */
function uniqueRandom($min, $max, $len)
{
    if ($min < 0 || $max < 0 || $len) {
        throw new LogicException(&#39;无效的参数&#39;);
    }
    if ($max <= $min) {
        throw new LogicException(&#39;大小传入错误&#39;);
    }
    $counter = 0;
    $result = array();
    while ($counter < $len) {
        $result[] = mt_rand($min, $max);
        $result = array_flip(array_flip($result));
        $counter = count($result);
    }
    shuffle($result);
    return $result;
}
登入後複製

其實可以利用索引來更加快速的生成不重複的隨機數,且效率甩上面函數幾條街。

/**
 * 生成指定长度不重复的字符串.
 *
 * @param integer $min 最小值.
 * @param integer $max 最大值.
 * @param integer $len 生成数组长度.
 *
 * @return array
 */
function uniqueRandom2($min, $max, $len)
{
    if ($min < 0 || $max < 0 || $len < 0) {
        throw new LogicException(&#39;无效的参数&#39;);
    }
    if ($max <= $min) {
        throw new LogicException(&#39;大小传入错误&#39;);
    }
    if (($max - $min + 2) < $len) {
        throw new LogicException("传入的范围不足以生成{$len}个不重复的随机数}");
    }
    $index = array();
    for ($i = $min; $i < $max + 1; $i++) {
        $index[$i] = $i;
    }
    $startOne = current($index);
    $endOne = end($index);
    for ($i = $startOne; $i < $endOne; $i++) {
        $one = mt_rand($i, $max);
        if ($index[$i] == $i) {
            $index[$i] = $index[$one];
            $index[$one] = $i;
        }
    }
    return array_slice($index, 0, $len);
}
登入後複製

此演算法與上面演算法相比巧妙之處在於:

  • 對自增索引進行隨機,不會有重複的問題,避免了去重的開銷

  • 用數組下標替代數組本身進行隨機,每取到一個隨機數字後就將其在取值範圍中排除,下一次只會在剩下的數字中取,一次遍歷就可以完成隨機數的選取。

相關學習推薦:PHP程式設計從入門到精通

以上是php如何取隨機數不重複?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
怎麼學好php
來自於 1970-01-01 08:00:00
0
0
0
PHP擴充intl
來自於 1970-01-01 08:00:00
0
0
0
php數據獲取?
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板