這篇文章將為大家詳細講解有關(guān)使用JavaScript怎么生成指定范圍隨機數(shù)和隨機序列,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián),為您提供重慶網(wǎng)站建設公司、網(wǎng)站制作、網(wǎng)站營銷推廣、網(wǎng)站開發(fā)設計,對服務成都陽臺護欄等多個行業(yè)擁有豐富的網(wǎng)站建設及推廣經(jīng)驗。創(chuàng)新互聯(lián)網(wǎng)站建設公司成立于2013年,提供專業(yè)網(wǎng)站制作報價服務,我們深知市場的競爭激烈,認真對待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發(fā)展進步,是我們永遠的責任!
在JavaScript中我們經(jīng)常使用Math.random()方法生成隨機數(shù),但是該方法生成的隨機數(shù)只是0-1之間的隨機數(shù)。先看如下常用方法的特征:
?1.Math.random(); 結(jié)果為0-1間的一個隨機數(shù)(包括0,不包括1)
?2.Math.floor(num); 參數(shù)num為一個數(shù)值,函數(shù)結(jié)果為num的整數(shù)部分。與取整數(shù)的parseInt(num)方法一樣。
?3.Math.round(num); 參數(shù)num為一個數(shù)值,函數(shù)結(jié)果為num四舍五入后的整數(shù)。
?4.Math.ceil(num); 返回大于等于n的最小整數(shù)。
合理使用上述方法生成指定范圍的隨機數(shù):
包含最小值不包含最大值的情況:
parseInt(num)取整,將傳入的num向小的整數(shù)轉(zhuǎn)化。將Math.random()乘以最大和最小的差值,在用parseInt處理(注意此時的范圍是【0-差值)),再加上最小值,就能得到包括最小值但不包括最大值的整數(shù)。
獲取包含最小值但不包括最大值的隨機數(shù),用如下函數(shù)實現(xiàn):
function getRandom1(start, end) { var length = end - start; var num = parseInt(Math.random() * (length) + start); return num; }
包括最大值但不包含最小值的情況:
Math.ceil(num)
取得大于等于num的最小整數(shù),也就是將傳入的num向大的整數(shù)轉(zhuǎn)化。將Math.random()乘以最大和最小的差值,在用Math.ceil()處理(注意此時的范圍是(0-差值】),在加上最小值,就能得到不包括最小值但包括最大值的整數(shù)。也就是將上面情況的parseInt改為Math.ceil()
獲取包含最大值但不包括最小值的隨機數(shù),用如下函數(shù)實現(xiàn):
function getRandom1(start, end) { var length = end - start; var num = Math.ceil(Math.random() * (length) + start); return num; }
最大值和最小值都包含的情況:
最大值和最小值都包含,此時可取值的范圍相比于上述兩種情況已經(jīng) 擴大1。在生成隨機數(shù)階段,就要將可能生成隨機數(shù)的范圍擴大1。使用parseInt向小的值取整可行,用Math.ceil(num)往大的值轉(zhuǎn)化也可以(轉(zhuǎn)化后需要-1)。不管采用哪種方式,關(guān)鍵在于生成隨機數(shù)階段將范圍加1.
采用parseInt的方法
function getRandom1(start, end) { var length = end - start + 1; var num = parseInt(Math.random() * (length) + end); return num; }
--------------------------------------------------------------------------------
一些時候,僅僅生成隨機數(shù)是不夠的,還需要將指定范圍的數(shù)值,按照隨機順序排列。我們將這個問題轉(zhuǎn)化為生成隨機數(shù)后加入數(shù)組并避免重復的問題。每次循環(huán)順序生成的數(shù)是隨機的,按照順序加入數(shù)組,以此實現(xiàn)數(shù)值大小的隨機排列。
生成指定范圍的隨機數(shù)序列:
隨機序列可直接通過sort排序方法實現(xiàn),將一個包含一組按順序排列的數(shù)字元素,調(diào)用sort方法,通過函數(shù)傳入隨機生成的值(可能為正可能為負),就可以將順序打亂,得到該數(shù)組的隨機序列。
如下:getNum()返回的是數(shù)字1-10按順序排列的數(shù)組,則得到的numArr就是1-10的隨機序列:
var numArr = getNum().sort(function () { return Math.random() - 0.5; });
自己寫邏輯生成隨機序列也是可行的:
定義存儲隨機數(shù)的數(shù)組,然后循環(huán)生成隨機數(shù),生成之后到已有數(shù)組中查找,如果存在,將標記變?yōu)閒alse表示產(chǎn)生的隨機數(shù)重復,根據(jù)標記值來決定是否加入數(shù)組。若加入數(shù)組成功,則數(shù)組下標index(表示數(shù)組元素個數(shù))自增,滿足條件退出循環(huán)。下面例子實現(xiàn)5-10之間的隨機序列(下面案例是左右包含的):
function getOrder(start, end) { var length = end - start; var myorder = new Array(); var index = 0; while (index < length+1) { var flag = true; var num = parseInt(Math.random() * (length + 1)); for (var i in myorder) { if (myorder[i] == num) { flag = false; } } if (flag == true) { myorder[index] = num; index++; } } alert(myorder.length); alert(myorder); } getOrder(5, 10);
JavaScript是一種直譯式的腳本語言,其解釋器被稱為JavaScript引擎,是瀏覽器的一部分,JavaScript是被廣泛用于客戶端的腳本語言,最早是在HTML網(wǎng)頁上使用,用來給HTML網(wǎng)頁增加動態(tài)功能。
關(guān)于使用JavaScript怎么生成指定范圍隨機數(shù)和隨機序列就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。