php取随机数不反复的要领:1、运用【rand(min,max)】函数发生随机数;2、运用【array_unique(arr)】对生成的数组举行去重;3、应用索引疾速的生成不反复的随机数。
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('无效的参数');
}
if ($max <= $min) {
throw new LogicException('大小传入毛病');
}
$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('无效的参数');
}
if ($max <= $min) {
throw new LogicException('大小传入毛病');
}
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怎样取随机数不反复?的细致内容,更多请关注ki4网别的相干文章!
收藏 | 0