求PHP语言随机自动生成不重复的数字
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求PHP语言随机自动生成不重复的数字相关的知识,希望对你有一定的参考价值。
要求比如排列1-999,必须是001不能是1,必须前面加0补足位数,
不要这种
要这种:08,17,05,18,15,02,04,11,12,13,09,07,14,19,06,01,20,16,03,10
要带0的,谢谢了。分数不多,请各位大神帮帮我,上面这种不带0的代码我已经有了。分享一下,
下面这段代码是不带0的
<?php
$tmp=array();
while(count($tmp)<20)
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
print join(',',$tmp);
?>
function mrand($count)
$code = '';
for($i=0;$i<$count;$i++)
$code .= mt_rand(0,9);
return $code;
你还可以在这基础上扩展,变成还可以选择随机码类型
//生成不重复数字
function gettmp($count)
$temp = aray();
$code = mrand(3);
$i = 0;
while($i < $count)
if(!in_array($code,$temp))
$temp[] = $code;
$i = $i + 1;
return $temp;
追问
就是自己不会扩展,求改完的代码,最好是在后面//加上意思
追答function gettmp($count)
$temp = aray();
$i = 0;
while($i < $count)
$code = mrand(3);
if(!in_array($code,$temp))
$temp[] = $code;
$i = $i + 1;
return $temp;
这一段不知道放在那里怎么用,求完整的代码,我直接拿来改在我的页面上就可以用的那种,谢谢了
追答$count1 = 20;//随机数的数量
$count2 = 3;//长度
$temp = array();
$i = 0;
while($i < $count1)
$code = '';
for($j=0;$j<$count2;$j++)
$code .= mt_rand(0,9);
if(!in_array($code,$temp))
$temp[] = $code;
$i = $i + 1;
echo implode(' , ',$temp);
可不可以自定义从0001-5999?
现在这个只能随机排那么多数字出来,不能限制最高数和最低数
$min = 1;
$max = 5999;
$count1 = 20;
$temp = array();
$i = 0;
while($i < $count1)
$code = mt_rand($min,$max);
if(!in_array($code,$temp))
$temp[] = str_pad($code,strlen($max),'0',STR_PAD_LEFT);
$i = $i + 1;
echo implode(' , ',$temp);
生成多个不重复的随机数字php
这个没什么好废话的;直奔主题来说思路;
首先是要用mt_rand()函数生成指定个数的随机数字;
然后使用array_unique()函数去重;
因为去重了;所以得到的数字就不够指定个数了;
所以;核心是要用while循环;直到得到指定个数的数字;
到这里基本可以是结束了;
对于追求完美的人来说;还可以再用个sort();
目的不是要用来排序;主要是将得到的数组key格式化;
用代码来说话;就如下;
/** * 生成不重复的随机数 * @param int $start 需要生成的数字开始范围 * @param int $end 结束范围 * @param int $length 需要生成的随机数个数 * @return array 生成的随机数 */ function get_rand_number($start=1,$end=10,$length=4){ $connt=0; $temp=array(); while($connt<$length){ $temp[]=mt_rand($start,$end); $data=array_unique($temp); $connt=count($data); } sort($data); return $data; }
当然;重点不是这个函数;重点是这个函数的思路;可以解决很多类似的问题;
以上是关于求PHP语言随机自动生成不重复的数字的主要内容,如果未能解决你的问题,请参考以下文章