久久久精品一区ed2k-女人被男人叉到高潮的视频-中文字幕乱码一区久久麻豆樱花-俄罗斯熟妇真实视频

php列表隨機不重復數(shù)據(jù) mysql生成不重復的隨機數(shù)

php生成不重復隨機數(shù)、數(shù)組的4種方法分享

下面寫幾種生成不重復隨機數(shù)的方法,直接上代碼吧

創(chuàng)新互聯(lián)公司專注于企業(yè)成都全網(wǎng)營銷推廣、網(wǎng)站重做改版、海豐網(wǎng)站定制設計、自適應品牌網(wǎng)站建設、H5建站商城開發(fā)、集團公司官網(wǎng)建設、外貿(mào)營銷網(wǎng)站建設、高端網(wǎng)站制作、響應式網(wǎng)頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為海豐等各大城市提供網(wǎng)站開發(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); //隨機打亂數(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()更好更快的隨機函數(shù)

$result

=

array_unique($result);

//刪除數(shù)組中重復的元素

}

return

$result;

}

function

rand3()

{

$result

=

array();

while(count($result)

COUNT)

{

$_tmp

=

mt_rand(1,

RANDOM_MAX);

if(!in_array($_tmp,

$result))

{ //當數(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);

}

}

?

PHP產(chǎn)生不重復隨機數(shù)的5個方法總結(jié)

無論是Web應用,還是WAP或者移動應用,隨機數(shù)都有其用武之地。在最近接觸的幾個小項目中,我也經(jīng)常需要和隨機數(shù)或者隨機數(shù)組打交道,所以,對于PHP如何產(chǎn)生不重復隨機數(shù)常用的幾種方法小結(jié)一下(ps:方法1、4、5是我常用的,其余來自網(wǎng)絡整理)

方法一:

復制代碼

代碼如下:

?php

$numbers

=

range

(1,50);

//shuffle

將數(shù)組順序隨即打亂

shuffle

($numbers);

//array_slice

取該數(shù)組中的某一段

$num=6;

$result

=

array_slice($numbers,0,$num);

print_r($result);

?

方法二:

復制代碼

代碼如下:

?php

$numbers

=

range

(1,20);

//播下隨機數(shù)發(fā)生器種子,可有可無,測試后對結(jié)果沒有影響

srand

((float)microtime()*1000000);

shuffle

($numbers);

//跳過list第一個值(保存的是索引)

while

(list(,

$number)

=

each

($numbers))

{

echo

"$number

";

}

?

方法三:

復制代碼

代碼如下:

?php

function

NoRand($begin=0,$end=20,$limit=5){

$rand_array=range($begin,$end);

shuffle($rand_array);//調(diào)用現(xiàn)成的數(shù)組隨機排列函數(shù)

return

array_slice($rand_array,0,$limit);//截取前$limit個

}

print_r(NoRand());

?

上述可以在1-20間隨機產(chǎn)生5個不重復的值

方法四:

復制代碼

代碼如下:

?php

$tmp=array();

while(count($tmp)5){

$tmp[]=mt_rand(1,20);

$tmp=array_unique($tmp);

}

print_r($tmp);

?

方法五:

復制代碼

代碼如下:

?php

$tmp

=

range(1,30);

print_r(array_rand($tmp,10));

?

這個可能是比叫簡單的了(ps:如果在range中指定了步長,就必須注意array_rand的第二個參數(shù)是否超出$tmp的長度)。

PHP提供非常豐富的數(shù)組函數(shù),產(chǎn)生隨機數(shù)大多可以從數(shù)組這個角度出發(fā),若你還有方法提供,歡迎給出,文章將持續(xù)更新。

php隨機生成數(shù)據(jù)庫中不存在、不重復數(shù)字

說下思路:

1. 將生成的數(shù)字保存到mysql數(shù)據(jù)庫,然后每次生成的號碼不能與數(shù)據(jù)庫的數(shù)字重復,請問怎么弄?

先讀取數(shù)據(jù)庫已存在的數(shù)字,將結(jié)果以數(shù)組格式,與rand(1,1000)的數(shù)組相比較計算差集,去除這部分數(shù)字(array_diff),再shuffle,得到新的隨機數(shù)。

我覺得,你完全可以建立一個序號表,比如,1-1000,每次用時先用隨機函數(shù)?。?-數(shù)據(jù)記錄數(shù))個數(shù)值,再用這個數(shù)值取得相應的記錄,當取出之后,刪除這個記錄,這樣保證記錄總數(shù)一直會減少且數(shù)字也不會重復。

2. 有沒有什么辦法生成的時候先生成一位數(shù)的,一位數(shù)生成滿了以后再生出兩位數(shù)的,兩位數(shù)滿了然后再三位數(shù)的,以此類推?

先獲取一位數(shù)的記錄,再從中隨機抽取一個,如果數(shù)據(jù)庫中沒有找到一位數(shù)的,就遞增一位數(shù),直到找到為止。

3. 代碼的執(zhí)行效率希望能越高越好!

如果想要代碼執(zhí)行效率,最好盡量減少與數(shù)據(jù)庫的交互。

php生成N個不重復的隨機數(shù)實例

有25幅作品拿去投票,一次投票需要選16幅,單個作品一次投票只能選擇一次。前面有個程序員捅了漏子,忘了把投票入庫,有200個用戶產(chǎn)生的投票序列為空。那么你會如何填補這個漏子?

當然向上級反映情況。但是我們這里討論的是技術(shù),就是需要生成1-25之間的16個不重復的隨機數(shù),去填補。具體怎么設計函數(shù)呢?將隨機數(shù)存入數(shù)組,再在數(shù)組中去除重復的值,即可生成一定數(shù)量的不重復隨機數(shù)。

程序如下:

復制代碼

代碼如下:

?php

/*

*

array

unique_rand(

int

$min,

int

$max,

int

$num

)

*

生成一定數(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);

}

shuffle($return);

return

$return;

}

$arr

=

unique_rand(1,

25,

16);

sort($arr);

$result

=

'';

for($i=0;

$i

count($arr);$i++)

{

$result

.=

$arr[$i].',';

}

$result

=

substr($result,

0,

-1);

echo

$result;

?

網(wǎng)頁題目:php列表隨機不重復數(shù)據(jù) mysql生成不重復的隨機數(shù)
瀏覽地址:http://www.sd-ha.com/article30/docposo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、標簽優(yōu)化、品牌網(wǎng)站設計、網(wǎng)站營銷、自適應網(wǎng)站、響應式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設