JavaScript生成指定范圍隨機(jī)數(shù)和隨機(jī)序列的方法
在JavaScript中我們經(jīng)常使用Math.random()方法生成隨機(jī)數(shù),但是該方法生成的隨機(jī)數(shù)只是0-1之間的隨機(jī)數(shù)。先看如下常用方法的特征:
•1.Math.random(); 結(jié)果為0-1間的一個隨機(jī)數(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ù)。
合理使用上述方法生成指定范圍的隨機(jī)數(shù):
包含最小值不包含最大值的情況:
parseInt(num)取整,將傳入的num向小的整數(shù)轉(zhuǎn)化。將Math.random()乘以最大和最小的差值,在用parseInt處理(注意此時的范圍是【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()處理(注意此時的范圍是(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;
}
最大值和最小值都包含的情況:
最大值和最小值都包含,此時可取值的范圍相比于上述兩種情況已經(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;
}
--------------------------------------------------------------------------------
一些時候,僅僅生成隨機(jī)數(shù)是不夠的,還需要將指定范圍的數(shù)值,按照隨機(jī)順序排列。我們將這個問題轉(zhuǎn)化為生成隨機(jī)數(shù)后加入數(shù)組并避免重復(fù)的問題。每次循環(huán)順序生成的數(shù)是隨機(jī)的,按照順序加入數(shù)組,以此實(shí)現(xiàn)數(shù)值大小的隨機(jī)排列。
生成指定范圍的隨機(jī)數(shù)序列:
隨機(jī)序列可直接通過sort排序方法實(shí)現(xiàn),將一個包含一組按順序排列的數(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ī)序列也是可行的:
定義存儲隨機(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ù)組元素個數(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ī)序列,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
- JS生成隨機(jī)數(shù)的多種方法匯總(不同范圍、類型的隨機(jī)數(shù))
- JavaScript中隨機(jī)數(shù)方法?Math.random()
- Javascript實(shí)現(xiàn)仿QQ隨機(jī)數(shù)驗(yàn)證
- Js生成隨機(jī)數(shù)/隨機(jī)字符串的方法小結(jié)【5種方法】
- JavaScript隨機(jī)數(shù)的組合問題案例分析
- js實(shí)現(xiàn)隨機(jī)數(shù)小游戲
- js控制隨機(jī)數(shù)生成概率代碼實(shí)例
- javaScript產(chǎn)生隨機(jī)數(shù)的用法小結(jié)
- JS隨機(jī)數(shù)產(chǎn)生代碼分享
- JavaScript中獲取隨機(jī)數(shù)的幾種方法小結(jié)
相關(guān)文章
微信小程序封裝網(wǎng)絡(luò)請求和攔截器實(shí)戰(zhàn)步驟
這篇文章主要介紹了微信小程序封裝網(wǎng)絡(luò)請求和攔截器實(shí)戰(zhàn)步驟,這樣可以提高開發(fā)效率,減少代碼重復(fù),同時也可以提高代碼的可維護(hù)性和可讀性2023-03-03
本地Bootstrap文件字體圖標(biāo)引入?yún)s無法顯示問題的解決方法
這篇文章主要為大家詳細(xì)介紹了本地Bootstrap文件字體圖標(biāo)引入?yún)s無法顯示問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12
javascript實(shí)現(xiàn)可拖動變色并關(guān)閉層窗口實(shí)例
這篇文章主要介紹了javascript實(shí)現(xiàn)可拖動變色并關(guān)閉層窗口的方法,涉及javascript操作層的樣式與屬性的相關(guān)技巧,需要的朋友可以參考下2015-05-05
Bootstrap php制作動態(tài)分頁標(biāo)簽
這篇文章主要為大家詳細(xì)介紹了Bootstrap php制作動態(tài)分頁標(biāo)簽的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12

