首頁  >  文章  >  後端開發  >  php隨機產生不在一個範圍隨機數

php隨機產生不在一個範圍隨機數

王林
王林原創
2019-09-19 11:53:592684瀏覽

php隨機產生不在一個範圍隨機數

想法:將產生的隨機數存入數組,然後在數組中移除重複的值,即可產生一定數量的不重複隨機數。

在PHP網站開發中,有時候我們需要產生指定範圍內一定數量的不重複隨機數,具體怎麼設計這個生產隨機數的函數呢?我們可以將隨機產生的數存入數組,但在存入的同時去除重複的值,即可產生一定數量的不重複隨機數。

也可以把指定範圍內的數值存進數組,再使用shuffle($array)打亂這個數組,然後再截取其中一定數量的值。但後面的做法在指定的隨機數字範圍太大的時候會產生一個較大的陣列。

下面給出第一種做法的程式碼,第二種做法比較簡單。

<?php
/*
* array unique_rand( int $min, int $max, int $num )
* 生成一定数量的不重复随机数,指定的范围内整数的数量必须
* 比要生成的随机数数量大
* $min 和 $max: 指定随机数的范围
* $num: 指定生成数量
*/
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);
  }
  //打乱数组,重新赋予数组新的下标
  shuffle($return);
  return $return;
}

//生成10个1到100范围内的不重复随机数
$arr = unique_rand(1, 100, 10);
echo implode($arr, ",");
?>

運行結果:48,5,19,36,63,72,82,77,46,16
補充說明:

1、產生隨機數字時我們用了 mt_rand() 函數。這個函數產生隨機數的平均速率比 rand() 快幾倍。

2、移除數組中的重複值時用了“翻轉法”,就是用 array_flip() 把數組的 key 和 value 交換兩次。這種做法在移除陣列重複值的同時效率也比用 array_unique() 快得多。

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

推薦教學:PHP影片教學

#

以上是php隨機產生不在一個範圍隨機數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn