JavaScript隨機(jī)數(shù)的組合問題案例分析
本文實(shí)例講述了JavaScript隨機(jī)數(shù)的組合問題。分享給大家供大家參考,具體如下:
隨機(jī)數(shù)的組合問題在面試時(shí)是經(jīng)常考的,比如之前我就被問到:“有一個(gè)可以生成1-5的隨機(jī)數(shù)函數(shù),怎樣把它擴(kuò)大到1-7?”
在解決這個(gè)問題之前,先來看看另外一個(gè)比較簡單的問題:“有一個(gè)可以生成1-7的函數(shù),怎樣把它縮小到1-5?”下面是一個(gè)生成1-7函數(shù)random7:
function random7() {
return Math.floor(Math.random() * 7 + 1);
}
如何把它轉(zhuǎn)成生成1-5的函數(shù)呢?這很簡單:在一個(gè)循環(huán)里面調(diào)用random7,直到它的值小于等于5就結(jié)束循環(huán)并返回該隨機(jī)數(shù)即可,如下:
function random5() {
var r = random7();
while(r > 5) {
r = random7();
}
return r;
}
上面的思路就是:如果生成的隨機(jī)數(shù)大于5,就繼續(xù)調(diào)用random7,直到它小于等于5為止。好吧,回歸正題,再來看一下1-5如何轉(zhuǎn)成1-7吧。下面是一個(gè)隨機(jī)生成1-5的函數(shù):
function random5() {
return Math.floor(Math.random() * 5 + 1);
}
我們現(xiàn)在的目的是要把它擴(kuò)大到1-7。有一種很自然的想法可能就是:一個(gè)random5()產(chǎn)生的隨機(jī)數(shù)范圍是1-5,那么兩個(gè)random5()相加的范圍就是2-10了,再減去1就是1-9了,所以,可以按照上面的思路,在random7里來個(gè)循環(huán),如果小于等于7就結(jié)束循環(huán)并且返回。如下:
function random7() {
var r = random5() + random5() - 1;
while(r > 7) {
r = random5() + random5() - 1;
}
return r;
}
這樣確實(shí)可以把1-5的范圍擴(kuò)大到1-7,但是問題來了:所謂隨機(jī)函數(shù),產(chǎn)生的每個(gè)值的概率是相等的,但是上面的方法產(chǎn)生的值概率相等嗎?我們可以使用概率論的組合知識算岀來:生成1有一種組合,就是random5() + random5() - 1;中的兩個(gè)random5()均是1,生成2有兩種組合,第一個(gè)random5()是1第二個(gè)是2,或者相反。顯然,它們的概率是不等的。所以這種方法是不行的。
為了實(shí)現(xiàn)生成的每個(gè)值的概率是相等的,就是使得每個(gè)值的組合數(shù)相等。一種可行的方法是使得每個(gè)值的組合只有一種,如下:
function random7() {
var r = (random5() - 1) * 5 + random5();
while(r > 7) {
r = (random5() - 1) * 5 + random5();
}
return r;
}
為什么這樣就會(huì)使得各個(gè)值的概率相等呢?首先來看一下(random5() - 1) * 5,容易算岀這個(gè)表達(dá)式生成的可選值是0,5,10,15,20,用它去跟random5()相加,因?yàn)閞andom5()的可選值是1,?。玻常?,5,所以兩者相加之后就會(huì)得到1-25之間的隨機(jī)數(shù),而且產(chǎn)生的每個(gè)值的組合均只有一種,所以它們的概率也是相等的。
也許有人會(huì)問,(random5() - 1) * 5,這里為什么是乘以5而不是其他呢?這是因?yàn)槌艘裕抵蠛蛂andom5()相加,得到的數(shù)是連續(xù)的并且是等概率的。
上面討論的都是特殊情形1-5和1-7之間的轉(zhuǎn)換,對于其他的一般情形,大家可以自己試試哈。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)組操作技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript排序算法總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
- 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種方法】
- js實(shí)現(xiàn)隨機(jī)數(shù)小游戲
- js控制隨機(jī)數(shù)生成概率代碼實(shí)例
- JavaScript生成指定范圍隨機(jī)數(shù)和隨機(jī)序列的方法
- javaScript產(chǎn)生隨機(jī)數(shù)的用法小結(jié)
- JS隨機(jī)數(shù)產(chǎn)生代碼分享
- JavaScript中獲取隨機(jī)數(shù)的幾種方法小結(jié)
相關(guān)文章
原生js操作checkbox用document.getElementById實(shí)現(xiàn)
js操作checkbox本人建議用document.getElementById(checkbox_id).checked不推薦使用jquery操作checkbox,感興趣的朋友不要錯(cuò)過2013-10-10
JavaScript canvas實(shí)現(xiàn)圍繞旋轉(zhuǎn)動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了JavaScript canvas實(shí)現(xiàn)圍繞旋轉(zhuǎn)動(dòng)畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11
js實(shí)現(xiàn)跨域的4種實(shí)用方法原理分析
這篇文章主要分析了js實(shí)現(xiàn)跨域的4種實(shí)用方法原理,主要是使用jsonp跨域,使用window.name來進(jìn)行跨域,對這方面感興趣的朋友可以參考一下2015-10-10
javascript動(dòng)態(tài)生成樹形菜單的方法
這篇文章主要介紹了javascript動(dòng)態(tài)生成樹形菜單的方法,涉及JavaScript針對頁面元素與屬性的動(dòng)態(tài)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
js鼠標(biāo)坐標(biāo)獲取常用的三個(gè)方法
這篇文章主要給大家介紹了js鼠標(biāo)坐標(biāo)獲取常用的三個(gè)方法,在 JavaScript中當(dāng)事件發(fā)生時(shí)獲取鼠標(biāo)的位置是件很重要的事件,需要的朋友可以參考下2023-09-09
基于JS實(shí)現(xiàn)二維碼圖片固定在右下角某處并跟隨滾動(dòng)條滾動(dòng)
這篇文章主要介紹了基于JS實(shí)現(xiàn)二維碼圖片固定在右下角某處并跟隨滾動(dòng)條滾動(dòng),代碼簡單易懂非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
thinkjs微信中控之微信鑒權(quán)登陸的實(shí)現(xiàn)代碼
這篇文章主要介紹了thinkjs微信中控之微信鑒權(quán)登陸的實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
使用typescript類型來實(shí)現(xiàn)快排詳情
這篇文章主要介紹了使用typescript類型來實(shí)現(xiàn)快排詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08

