在JavaScript中我們經(jīng)常使用Math.random()方法生成隨機(jī)數(shù),但是該方法生成的隨機(jī)數(shù)只是0-1之間的隨機(jī)數(shù)。先看如下常用方法的特征:
•1.Math.random(); 結(jié)果為0-1間的一個(gè)隨機(jī)數(shù)(包括0,不包括1)
•2.Math.floor(num); 參數(shù)num為一個(gè)數(shù)值,函數(shù)結(jié)果為num的整數(shù)部分。與取整數(shù)的parseInt(num)方法一樣。
•3.Math.round(num); 參數(shù)num為一個(gè)數(shù)值,函數(shù)結(jié)果為num四舍五入后的整數(shù)。
•4.Math.ceil(num); 返回大于等于n的最小整數(shù)。
合理使用上述方法生成指定范圍的隨機(jī)數(shù):
包含最小值不包含最大值的情況:
parseInt(num)取整,將傳入的num向小的整數(shù)轉(zhuǎn)化。將Math.random()乘以最大和最小的差值,在用parseInt處理(注意此時(shí)的范圍是【0-差值)),再加上最小值,就能得到包括最小值但不包括最大值的整數(shù)。
獲取包含最小值但不包括最大值的隨機(jī)數(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()處理(注意此時(shí)的范圍是(0-差值】),在加上最小值,就能得到不包括最小值但包括最大值的整數(shù)。也就是將上面情況的parseInt改為Math.ceil()
獲取包含最大值但不包括最小值的隨機(jī)數(shù),用如下函數(shù)實(shí)現(xiàn):
function getRandom1(start, end) { var length = end - start; var num = Math.ceil(Math.random() * (length) + start); return num; }最大值和最小值都包含的情況:
最大值和最小值都包含,此時(shí)可取值的范圍相比于上述兩種情況已經(jīng) 擴(kuò)大1。在生成隨機(jī)數(shù)階段,就要將可能生成隨機(jī)數(shù)的范圍擴(kuò)大1。使用parseInt向小的值取整可行,用Math.ceil(num)往大的值轉(zhuǎn)化也可以(轉(zhuǎn)化后需要-1)。不管采用哪種方式,關(guān)鍵在于生成隨機(jī)數(shù)階段將范圍加1.
采用parseInt的方法
function getRandom1(start, end) { var length = end - start + 1; var num = parseInt(Math.random() * (length) + end); return num; }--------------------------------------------------------------------------------
一些時(shí)候,僅僅生成隨機(jī)數(shù)是不夠的,還需要將指定范圍的數(shù)值,按照隨機(jī)順序排列。我們將這個(gè)問題轉(zhuǎn)化為生成隨機(jī)數(shù)后加入數(shù)組并避免重復(fù)的問題。每次循環(huán)順序生成的數(shù)是隨機(jī)的,按照順序加入數(shù)組,以此實(shí)現(xiàn)數(shù)值大小的隨機(jī)排列。
生成指定范圍的隨機(jī)數(shù)序列:
隨機(jī)序列可直接通過sort排序方法實(shí)現(xiàn),將一個(gè)包含一組按順序排列的數(shù)字元素,調(diào)用sort方法,通過函數(shù)傳入隨機(jī)生成的值(可能為正可能為負(fù)),就可以將順序打亂,得到該數(shù)組的隨機(jī)序列。
如下:getNum()返回的是數(shù)字1-10按順序排列的數(shù)組,則得到的numArr就是1-10的隨機(jī)序列:
var numArr = getNum().sort(function () { return Math.random() - 0.5; });自己寫邏輯生成隨機(jī)序列也是可行的:
定義存儲(chǔ)隨機(jī)數(shù)的數(shù)組,然后循環(huán)生成隨機(jī)數(shù),生成之后到已有數(shù)組中查找,如果存在,將標(biāo)記變?yōu)閒alse表示產(chǎn)生的隨機(jī)數(shù)重復(fù),根據(jù)標(biāo)記值來決定是否加入數(shù)組。若加入數(shù)組成功,則數(shù)組下標(biāo)index(表示數(shù)組元素個(gè)數(shù))自增,滿足條件退出循環(huán)。下面例子實(shí)現(xiàn)5-10之間的隨機(jī)序列(下面案例是左右包含的):
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);總結(jié)
以上所述是小編給大家介紹的JavaScript生成指定范圍隨機(jī)數(shù)和隨機(jī)序列,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注