您好,很高興回答您的問題

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名與空間、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、武侯網(wǎng)站維護(hù)、網(wǎng)站推廣。
$numbers?=?range?(1,50);
//將數(shù)組順序隨機(jī)打亂
shuffle?($numbers);
//取該數(shù)組中的某一段
$result?=?array_slice($numbers,0,6);
print_r($result);
$tmp=array();
while(count($tmp)5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
每次隨機(jī)取出一個(gè)數(shù)之后,應(yīng)該刪除這個(gè)數(shù),才可以保證下次不取到它。例如你的100個(gè)數(shù),第一次隨機(jī)取一個(gè),然后刪除它,下次再剩余的99里面隨機(jī)取一個(gè),這樣就不會(huì)重復(fù)了。
寫代碼沒難度了吧,你寫寫看,如果希望我繼續(xù)回答,建議你粘貼一下你寫的內(nèi)容,不完整或者錯(cuò)誤沒關(guān)系,至少你去思考了的,而且我看了代碼知道你錯(cuò)在哪里,才可以針對(duì)性的講解。
沒空等你寫代碼了,我把我的貼出來,今天晚上要熬夜加班,沒空回來看帖子了,不好意思,希望你認(rèn)真學(xué)習(xí)。
?php
$arr=array();
for ($i=1;$i=100;$i++) array_push($arr,$i);
print_r($arr);
for ($i=1;$i=100;$i++){
$n=rand(0,count($arr)-1);//產(chǎn)生隨機(jī)數(shù),最小值是0,最大值是數(shù)組剩余元素可數(shù)-1
echo $arr[$n]," ";//顯示取的隨機(jī)數(shù)
array_slice($arr,$n,1);//刪除剛才取到的數(shù)
}
?
下面寫幾種生成不重復(fù)隨機(jī)數(shù)的方法,直接上代碼吧
復(fù)制代碼
代碼如下:
?php
define('RANDOM_MAX',
100);
define('COUNT',
10);
echo
'max
random
num:
'.RANDOM_MAX,
'
;result
count:'.COUNT,
'br/';
invoke_entry('rand1');
invoke_entry('rand2');
invoke_entry('rand3');
invoke_entry('rand4');
function
invoke_entry($func_name)
{
$time
=
new
time();
$time-time_start();
call_user_func($func_name);
echo
$func_name.'
time
spend:
',
$time-time_spend();
echo
'br/';
}
function
rand1()
{
$numbers
=
range
(1,
RANDOM_MAX);
shuffle($numbers); //隨機(jī)打亂數(shù)組
$result
=
array_slice($numbers,
1,
COUNT);
return
$result;
}
function
rand2()
{
$result
=
array();
while(count($result)
COUNT)
{
$result[]
=
mt_rand(1,
RANDOM_MAX); //mt_rand()是比rand()更好更快的隨機(jī)函數(shù)
$result
=
array_unique($result);
//刪除數(shù)組中重復(fù)的元素
}
return
$result;
}
function
rand3()
{
$result
=
array();
while(count($result)
COUNT)
{
$_tmp
=
mt_rand(1,
RANDOM_MAX);
if(!in_array($_tmp,
$result))
{ //當(dāng)數(shù)組中不存在相同的元素時(shí),才允許插入
$result[]
=
$_tmp;
}
}
return
$result;
}
function
rand4()
{
$result
=
array();
while
(count($result)
COUNT)
{
$result[]
=
mt_rand(1,
RANDOM_MAX);
$result
=
array_flip(array_flip($result)); //array_flip將數(shù)組的key和value交換
}
return
$result;
}
class
time
{
private
$_start;
public
function
time_start()
{
$this-_start
=
$this-microtime_float();
}
public
function
time_spend()
{
return
$this-microtime_float()
-
$this-_start;
}
private
function
microtime_float()
{
list($usec,
$sec)
=
explode("
",
microtime());
return
((float)$usec
+
(float)$sec);
}
}
?
無論是Web應(yīng)用,還是WAP或者移動(dòng)應(yīng)用,隨機(jī)數(shù)都有其用武之地。在最近接觸的幾個(gè)小項(xiàng)目中,我也經(jīng)常需要和隨機(jī)數(shù)或者隨機(jī)數(shù)組打交道,所以,對(duì)于PHP如何產(chǎn)生不重復(fù)隨機(jī)數(shù)常用的幾種方法小結(jié)一下(ps:方法1、4、5是我常用的,其余來自網(wǎng)絡(luò)整理)
方法一:
復(fù)制代碼
代碼如下:
?php
$numbers
=
range
(1,50);
//shuffle
將數(shù)組順序隨即打亂
shuffle
($numbers);
//array_slice
取該數(shù)組中的某一段
$num=6;
$result
=
array_slice($numbers,0,$num);
print_r($result);
?
方法二:
復(fù)制代碼
代碼如下:
?php
$numbers
=
range
(1,20);
//播下隨機(jī)數(shù)發(fā)生器種子,可有可無,測(cè)試后對(duì)結(jié)果沒有影響
srand
((float)microtime()*1000000);
shuffle
($numbers);
//跳過list第一個(gè)值(保存的是索引)
while
(list(,
$number)
=
each
($numbers))
{
echo
"$number
";
}
?
方法三:
復(fù)制代碼
代碼如下:
?php
function
NoRand($begin=0,$end=20,$limit=5){
$rand_array=range($begin,$end);
shuffle($rand_array);//調(diào)用現(xiàn)成的數(shù)組隨機(jī)排列函數(shù)
return
array_slice($rand_array,0,$limit);//截取前$limit個(gè)
}
print_r(NoRand());
?
上述可以在1-20間隨機(jī)產(chǎn)生5個(gè)不重復(fù)的值
方法四:
復(fù)制代碼
代碼如下:
?php
$tmp=array();
while(count($tmp)5){
$tmp[]=mt_rand(1,20);
$tmp=array_unique($tmp);
}
print_r($tmp);
?
方法五:
復(fù)制代碼
代碼如下:
?php
$tmp
=
range(1,30);
print_r(array_rand($tmp,10));
?
這個(gè)可能是比叫簡(jiǎn)單的了(ps:如果在range中指定了步長,就必須注意array_rand的第二個(gè)參數(shù)是否超出$tmp的長度)。
PHP提供非常豐富的數(shù)組函數(shù),產(chǎn)生隨機(jī)數(shù)大多可以從數(shù)組這個(gè)角度出發(fā),若你還有方法提供,歡迎給出,文章將持續(xù)更新。
文章題目:php+隨機(jī)取不重復(fù)數(shù)據(jù) php產(chǎn)生不重復(fù)的隨機(jī)數(shù)
文章URL:http://www.chinadenli.net/article16/dopgjdg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、面包屑導(dǎo)航、建站公司、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)