溫馨提示×

溫馨提示×

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

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

使用PHP怎么生成指定范圍的N個不重復(fù)隨機數(shù)

發(fā)布時間:2021-06-07 16:32:02 來源:億速云 閱讀:202 作者:Leah 欄目:開發(fā)技術(shù)

使用PHP怎么生成指定范圍的N個不重復(fù)隨機數(shù)?針對這個問題,這篇文章詳細介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

思路:將生成的隨機數(shù)存入數(shù)組,再在數(shù)組中去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機數(shù)。

在PHP網(wǎng)站開發(fā)中,有時候我們需要生成指定范圍內(nèi)一定數(shù)量的不重復(fù)隨機數(shù),具體怎么設(shè)計這個生產(chǎn)隨機數(shù)的函數(shù)呢?我們可以將隨機產(chǎn)生的數(shù)存入數(shù)組,但在存入的同時去除重復(fù)的值,即可生成一定數(shù)量的不重復(fù)隨機數(shù)。當(dāng)然也可以把指定范圍內(nèi)的數(shù)值存進數(shù)組,再使用shuffle($array)打亂這個數(shù)組,然后再截取其中一定數(shù)量的值。但后面的一種做法在指定的隨機數(shù)范圍太大的時候會產(chǎn)生一個較大的數(shù)組。

下面給出第一種做法的代碼,第二種做法更簡單,大家可以嘗試下,其實也差不多

<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定數(shù)量的不重復(fù)隨機數(shù),指定的范圍內(nèi)整數(shù)的數(shù)量必須
* 比要生成的隨機數(shù)數(shù)量大
* $min 和 $max: 指定隨機數(shù)的范圍
* $num: 指定生成數(shù)量
*/
function unique_rand($min, $max, $num) {
  $count = 0;
  $return = array();
  while ($count < $num) {
    $return[] = mt_rand($min, $max);
    $return = array_flip(array_flip($return));
    $count = count($return);
  }
  //打亂數(shù)組,重新賦予數(shù)組新的下標
  shuffle($return);
  return $return;
}

//生成10個1到100范圍內(nèi)的不重復(fù)隨機數(shù)
$arr = unique_rand(1, 100, 10);
echo implode($arr, ",");
?>

程序運行如下:

48,5,19,36,63,72,82,77,46,16

補充幾點說明:

1、生成隨機數(shù)時我們用了 mt_rand() 函數(shù)。這個函數(shù)生成隨機數(shù)的平均速度要比 rand() 快幾倍。

2、去除數(shù)組中的重復(fù)值時用了“翻轉(zhuǎn)法”,就是用 array_flip() 把數(shù)組的 key 和 value 交換兩次。這種做法在去除數(shù)組重復(fù)值的同時效率也比用 array_unique() 快得多。

3、返回數(shù)組前,先使用 shuffle() 為數(shù)組賦予新的鍵名,保證鍵名是 0-n 連續(xù)的數(shù)字。如果不進行此步驟,可能在刪除重復(fù)值時造成鍵名不連續(xù),如果用for遍歷的時候會有問題,但如果用foreach或不需要遍歷的時候可以不需要shuffle。

關(guān)于使用PHP怎么生成指定范圍的N個不重復(fù)隨機數(shù)問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI