JavaScript實(shí)現(xiàn)微信紅包算法及問題解決方法
專欄停更了很久,向大家說聲抱歉。今天的主題是使用JavaScript模擬實(shí)現(xiàn)微信搶紅包的算法。這個(gè)題目看起來很簡單,不就是一個(gè)隨機(jī)函數(shù)嗎?我們一起實(shí)現(xiàn)看看。
我們假設(shè)有一個(gè)100元的紅包,要發(fā)給10個(gè)人。為了保證公平,算法需要保證以下的原則:
- 每個(gè)人最少能搶到0.01元
- 每個(gè)人的機(jī)會平等
- 所有人的金額之和等于100元
1.簡單的隨機(jī)函數(shù)實(shí)現(xiàn)
很多朋友的一般思路是:
第一步:從0-100中隨機(jī)一個(gè)數(shù),得到第一個(gè)紅包金額。
第二步:從0-剩余金額中隨機(jī)一個(gè)數(shù),得到第二個(gè)紅包金額。
第三步:...
最后一步把剩余的錢都給最后一個(gè)人。
以此類推,得到全部的10 個(gè)紅包。但是不知道大家注意到?jīng)]有,這樣存在明顯的 不公平 。先搶的人比較有優(yōu)勢,第一個(gè)人的隨機(jī)范圍是0-100,有可能得到較大的金額。而最后一個(gè)人的隨機(jī)范圍就會很小,如果第一個(gè)人搶到了90塊錢,那么最后一個(gè)人就不可能有的到超過10塊錢的機(jī)會。我們用代碼模擬一下這個(gè)過程:
測試結(jié)果如下:
細(xì)心的朋友會注意到,余額的值不正確,這是JavaScript浮點(diǎn)數(shù)運(yùn)算的已知問題。當(dāng)然解決的方式有很多,如果你有好的辦法歡迎你給我留言。
總結(jié)
以上所述是小編給大家介紹的JavaScript實(shí)現(xiàn)微信紅包算法及問題解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 使用AutoJs實(shí)現(xiàn)微信搶紅包的代碼
- 基于js實(shí)現(xiàn)抽紅包并分配代碼實(shí)例
- js canvas實(shí)現(xiàn)紅包照片效果
- js+css實(shí)現(xiàn)紅包雨效果
- 利用adb shell和node.js實(shí)現(xiàn)抖音搶紅包功能(推薦)
- Javascript網(wǎng)頁搶紅包外掛實(shí)現(xiàn)分享
- js實(shí)現(xiàn)微信/QQ直接跳轉(zhuǎn)到支付寶APP打開口令領(lǐng)紅包功能
- js仿微信搶紅包功能
- 基于JavaScript實(shí)現(xiàn)微信搶紅包功能
- js實(shí)現(xiàn)指定紅包順序和金額算法
相關(guān)文章
cocos creator Touch事件應(yīng)用(觸控選擇多個(gè)子節(jié)點(diǎn)的實(shí)例)
下面小編就為大家?guī)硪黄猚ocos creator Touch事件應(yīng)用(觸控選擇多個(gè)子節(jié)點(diǎn)的實(shí)例)。小編覺得挺不錯(cuò)的,現(xiàn)在就想給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09JavaScript Ajax實(shí)現(xiàn)異步通信
這篇文章主要為大家詳細(xì)介紹了JavaScript Ajax實(shí)現(xiàn)異步通信的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12可能是全網(wǎng)最詳細(xì)小程序中使用echarts的教程
在開發(fā)微信小程序時(shí),有需求需要使用到柱狀圖,餅圖等圖表,下面這篇文章主要給大家介紹了關(guān)于小程序中使用echarts的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10Javascript繼承機(jī)制的設(shè)計(jì)思想分享
我花了很多時(shí)間,學(xué)習(xí)這個(gè)部分,還做了很多筆記。但是都屬于強(qiáng)行記憶,無法從根本上理解。2011-08-08微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用)
這篇文章主要介紹了微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07