佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > ASP隨機(jī)數(shù)RND()使用方法

ASP隨機(jī)數(shù)RND()使用方法

熱門標(biāo)簽:Linux服務(wù)器 Mysql連接數(shù)設(shè)置 銀行業(yè)務(wù) 阿里云 服務(wù)器配置 團(tuán)購(gòu)網(wǎng)站 電子圍欄 科大訊飛語(yǔ)音識(shí)別系統(tǒng)

ASP函數(shù)rnd()

函數(shù)rnd()返回一個(gè)0到1之間的隨機(jī)數(shù)。

使用方法如下:

response.write rnd() '其可能的返回值:0.2357746

如果你想用rnd()函數(shù)來(lái)返回某一范圍內(nèi)的整數(shù),比方說(shuō)大于等于0而小于等于特定整數(shù)upperbound的數(shù)字,你可以使用如下方法:

response.write int((upperbound+1)*rnd)

例如,下面的語(yǔ)句將返回一個(gè)0和5之間的整數(shù),包括0和5:

response.write int((5+1)*rnd)

如果你想獲得一個(gè)處在某個(gè)范圍內(nèi)的隨機(jī)數(shù),該范圍有一個(gè)大于0的下界lowerbound,可以使用如下的方法:

response.write int((upperbound-lowerbound+1)*rnd+lowerbound)

例如,下面的腳本產(chǎn)生一個(gè)50到75之間的整數(shù),包括50和75:

response.write int((75-50+1)*rnd+50)

但是,有個(gè)問(wèn)題,一個(gè)隨機(jī)數(shù)產(chǎn)生了,但是每次都是同樣的隨機(jī)數(shù)。這也許會(huì)讓你十分不解,有一個(gè)特殊的語(yǔ)句可以幫助解決這個(gè)問(wèn)題,那就是randomize語(yǔ)句。

randomize語(yǔ)句用來(lái)強(qiáng)制函數(shù)rnd使用一個(gè)新的隨機(jī)數(shù)序列。randomize語(yǔ)句通過(guò)計(jì)算機(jī)的系統(tǒng)計(jì)時(shí)器,為函數(shù)rnd提供一個(gè)新的種子值。

函數(shù)RND()是一個(gè)非常重要的函數(shù)。如果你想建立一個(gè)隨機(jī)的問(wèn)候語(yǔ),一個(gè)日期的隨機(jī)提示,或者甚至一個(gè)游戲,你將要使用這個(gè)函數(shù)。

函數(shù)RND()返回一個(gè)0到1之間的隨機(jī)數(shù)。這里有這個(gè)函數(shù)的一個(gè)例子及其可能的返回值:
%=RND()%>
0.7055643
典型情況下,你更感興趣的是用這個(gè)函數(shù)來(lái)返回處在一定范圍內(nèi)的整數(shù)。要返回一個(gè)大于等于0而小于某個(gè)特定整數(shù)的數(shù)字,你可以使用如下的語(yǔ)句:

%=INT((upperbound+1)*RND)%>

用你想產(chǎn)生的最大隨機(jī)數(shù)代替表達(dá)式upperbound。例如,下面的腳本返回一個(gè)0和5之間的數(shù),包括0和5:
%=INT(5+1)*RND)%>
如果你想產(chǎn)生一個(gè)處在某個(gè)范圍內(nèi)的隨機(jī)數(shù),該范圍有一個(gè)大于0的下界,可以使用如下的腳本:

%=INT((upperbound – lowerbound + 1)*RND+lowerbound)%>

例如,下面的腳本產(chǎn)生一個(gè)50到75之間的隨機(jī)數(shù)(包括50和75):

%=INT((75-50+1)*RND+50)%>

無(wú)論何時(shí)使用函數(shù)RND(),它將以同樣的順序返回同樣的隨機(jī)數(shù),這也許另你吃驚。考慮如下的例子:

%
Pick_Greeting=INT((2+1)*RND)
SELECT CASE Pick_Greeting
CASE 0
Greeting=”Welcome!”
CASE 1
Greeting=”Hello!”
CASE 2
Greeting=”Happy to see you!”
END SELECT
%>
%=Greeting%>

這個(gè)腳本建立并打印一個(gè)隨機(jī)的問(wèn)候語(yǔ)。但是,它有可能并不按你想象的方式工作。無(wú)論何時(shí)有人下載了包含這段腳本的網(wǎng)頁(yè),將有同樣的隨機(jī)問(wèn)候語(yǔ)被打印。如果有人多次回到這個(gè)網(wǎng)頁(yè),他或她將得到同樣的問(wèn)候。一個(gè)隨機(jī)數(shù)產(chǎn)生了,但是每次都是同樣的隨機(jī)數(shù)。
有一個(gè)特殊的語(yǔ)句可以幫助解決這個(gè)問(wèn)題。RANDOMIZE語(yǔ)句用來(lái)強(qiáng)制函數(shù)RND()使用一個(gè)新的隨機(jī)數(shù)序列。RANDOMIZE語(yǔ)句通過(guò)計(jì)算機(jī)的系統(tǒng)計(jì)時(shí)器,為函數(shù)RND()提供一個(gè)新的種子值。下面的例子顯示了如何修改上面的例子,使其正確工作:

%
RANDOMIZE
Pick_Greeting=INT((2+1)*RND)
SELECT CASE Pick_Greeting
CASE 0
Greeting=”Welcome!”
CASE 1
Greeting=”Hello!”
CASE 2
Greeting=”Happy to see you!”
END SELECT
%>
%=Greeting%>

這個(gè)腳本可以正確工作。每次執(zhí)行這個(gè)腳本時(shí),將會(huì)產(chǎn)生一個(gè)新的隨機(jī)問(wèn)候。RANDOMIZE語(yǔ)句強(qiáng)制函數(shù)RND()使用新的隨機(jī)數(shù)序列。
最后,如果你對(duì)函數(shù)RND()所產(chǎn)生的數(shù)值的分布感到好奇,你可以用下面的腳本來(lái)確定它:

%
CONST upperbound=9,iterations=100
REDIM DIST(upperbound)
RANDOMIZE
FOR i=1 to iterations
rnd_num=INT((upperbound+1)*RND)
DIST(rnd_num)=DIST(rnd_num)”#”
NEXT
FOR i=0 to upperbound
%>
%=i” : “DIST(i)%>BR>
%
NEXT
%>

這段腳本在0到9之間產(chǎn)生100個(gè)隨機(jī)數(shù)。它跟蹤對(duì)于每一個(gè)值有多少個(gè)隨機(jī)數(shù)產(chǎn)生。最后,它打印一個(gè)代表結(jié)果的條形圖。

您可能感興趣的文章:
  • asp隨機(jī)數(shù) 隨機(jī)產(chǎn)生N位由數(shù)字和字母組成的密碼
  • asp實(shí)現(xiàn)生成由數(shù)字,大寫字母,小寫字母指定位數(shù)的隨機(jī)數(shù)
  • ASP中一個(gè)用VBScript寫的隨機(jī)數(shù)類
  • 深思 PHP 數(shù)組遍歷的差異(array_diff 的實(shí)現(xiàn))
  • ASP生成隨機(jī)數(shù) ASP生成不重復(fù)隨機(jī)數(shù)

標(biāo)簽:蚌埠 廣元 衡水 江蘇 萍鄉(xiāng) 棗莊 大理 衢州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP隨機(jī)數(shù)RND()使用方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    延吉市| 商南县| 阳江市| 皋兰县| 崇左市| 同德县| 措勤县| 郁南县| 扎鲁特旗| 乌兰县| 怀宁县| 蕲春县| 绥宁县| 本溪| 韶山市| 乐都县| 合肥市| 全椒县| 祁阳县| 宁武县| 济阳县| 清新县| 两当县| 海口市| 乌恰县| 堆龙德庆县| 和龙市| 伊川县| 黑山县| 裕民县| 方山县| 波密县| 商河县| 阿巴嘎旗| 托里县| 隆回县| 兴和县| 高州市| 黎平县| 师宗县| 浑源县|