亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深思 PHP 數(shù)組遍歷的差異(array_diff 的實現(xiàn))

 更新時間:2006年06月07日 00:00:00   作者:  
前兩天看到有人要編個考試系統(tǒng),當時只是簡單回了下用隨機函數(shù)RND

  實際一般需要從數(shù)據(jù)庫中隨機提取N道題目。

  以下代碼都基于VBS;

  通常的編寫類似這樣的

'產(chǎn)生不重復(fù)隨機數(shù)
function rndarray(istart,iend,sum)
dim arrayid(),i,j,blnre,temp,iloop,eloop
redim arrayid(sum-1)
i=0
iloop=0
eloop=0
blnre=false
randomize
do while i<sum
temp=int(rnd*(iend-istart+1)+istart)
if i=0 then
arrayid(0)=temp
i=i+1
iloop=iloop+1
else

for j=0 to i-1
if arrayid(j)=temp then
blnre=true
iloop=iloop+1
exit for'這一句很重要,防止多余的循環(huán)
else
iloop=iloop+1
end if
next

 if blnre=false then
 arrayid(i)=temp
 i=i+1
 else
 blnre=false
 end if

end if
eloop=eloop+iloop
iloop=0
loop
rndarray=join(arrayid)&"循環(huán)次數(shù):"&eloop
end function

response.write rndarray(1,10,5)&"<br>"'調(diào)用過程


  PS。其中的iloop、eloop是為了計算循環(huán)次數(shù)而已。

  以上,大多數(shù)人的都是用這種方法編寫的,生成一個隨機數(shù),然后再和以前生成的做比較,判斷是否可用;

  但這不是一種AI的,或者說有效率的方法,為什么不用兩個數(shù)組呢?

  數(shù)組1,存放需要的字符串,或數(shù)字等,數(shù)組2存放生成的隨機數(shù);當每次隨機生成中間變量temp的一個下標x,賦給數(shù)組2,然后從數(shù)組1中,去掉下標為x的數(shù)字,賦給中間變量temp;這樣每生成一個隨機數(shù),就從數(shù)組1中拿掉這個數(shù),下次再生成一個數(shù)就不會重復(fù)了,這種產(chǎn)生隨機數(shù)的方法原理實際是從數(shù)組1中提取。

  方法二

function rndstr(istart,iend,isum)
dim i,j,vntarray()
redim vntarray(iend-istart)
j=istart
for i=0 to iend-istart
vntarray(i)=j
j=j+1
next

dim vntarray2(),temp,x,y
redim vntarray2(isum-1)
y=iend-istart+1
x=0
temp=vntarray
do while x<isum
dim a
randomize
vntarray2(x)=temp(int(rnd*y))
a=" "&vntarray2(x)&" "
temp=split(trim(replace(chr(32)&join(temp)&chr(32),a," ")))
x=x+1
y=y-1
loop
rndstr=join(vntarray2)
end function

response.write rndstr(1,5,2)


  這樣,是不是更簡單呢

  展開一下,假如要生成隨機字符串,包含字母數(shù)字時,僅需為數(shù)組1賦值時,用函數(shù)chr(num);

  假設(shè),需要做一個手機中獎的頁面程序。

  首先把值賦給數(shù)組1,可以130....~139....循環(huán)賦值,當然實際使用時從數(shù)據(jù)庫中把已有的賦值,然后再隨機提取賦給數(shù)組2;

  最后,再修飾一下

temp=replace(join(array2),chr(32),"")
phone=left(temp,6)&"***"&right(temp,2)

  得到類似137648***58的結(jié)果,呵呵

  寫那么多,累死了~~

相關(guān)文章

最新評論