微信紅包算法MATLAB實(shí)現(xiàn)

上午看到基友分享的微信紅包算法的文章,代碼很短,春節(jié)期間紅包太火了,看完就也想實(shí)現(xiàn)下玩玩,原代碼是JAVA的,沒(méi)接觸過(guò)JAVA,所以看懂后改成了MATLAB的。

原文鏈接:微信紅包隨機(jī)算法初探?,?作者:陳鵬。

所寫(xiě)MATLAB代碼如下:


% -----------------------------------

?%Test for WeChat MoneyPackageAlgrithm

?% Email:xiaolongjee@mail.nwpu.edu.cn

?% 2016.02.13 - 17:32;

% -----------------------------------

close all;

clc;

clear all;

global leftMoneyPackage

MaxTestTimes = 12; % Set as 4*x for display;

row = 4;

col = MaxTestTimes / row;

figure;

for times = 1:MaxTestTimes

? ? leftMoneyPackage.peoples = 35;

? ? leftMoneyPackage.leftmoney = 0.35;

? ? n = leftMoneyPackage.peoples;

? ? cache = zeros(n,1);

? ? for i = 1:n

? ? ? ? cache(i) = getRandomMoney();

? ? end

? ? subplot(col, row,times);

? ? bar(cache, 'r');

end


function money = getRandomMoney()

? ? global leftMoneyPackage

? ? if (leftMoneyPackage.peoples == 1)

? ? ? ? leftMoneyPackage.peoples = 0;

? ? ? ? money =? round(leftMoneyPackage.leftmoney * 100) / 100;

? ? else

? ? ? ? minGet = 0.01;

? ? ? ? maxGet = leftMoneyPackage.leftmoney /? ? leftMoneyPackage.peoples * 2;

? ? ? ? r = random('Uniform', 0, 1);

? ? ? ? money = r * maxGet;

? ? ? ? if(money < minGet)

? ? ? ? ? ? money = minGet;

? ? ? ? end

? ? ? ? money = floor(money * 100) / 100;

? ? ? ? leftMoneyPackage.peoples =? ? leftMoneyPackage.peoples - 1;

? ? ? ? leftMoneyPackage.leftmoney =? ? leftMoneyPackage.leftmoney - money;

? ? end

? ? end


寫(xiě)完做了幾組測(cè)試(每組重復(fù)12次):

1.35個(gè)人瓜分0.35元,理論每人為最低值0.01,正確。

35個(gè)人瓜分0.35元

2.35個(gè)人瓜分0.36元,理論34人為最低值0.01,1人0.02,正確。

35個(gè)人瓜分0.36元

3. 35人瓜分50元,作為普通組。

35人瓜分50元

最后建了個(gè)小群實(shí)際發(fā)紅包重復(fù)跑程序,數(shù)據(jù)基本能吻合,手氣最佳一般在均值2倍附近。

完畢,成就感滿(mǎn)滿(mǎn)。

想知道具原理及各種說(shuō)明的點(diǎn)擊文章開(kāi)頭鏈接。


北一? 2016.02.13

版權(quán)歸作者所有,轉(zhuǎn)載請(qǐng)注明作者、出處,其他任何形式的使用請(qǐng)聯(lián)系我。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • **2014真題Directions:Read the following text. Choose the be...
    又是夜半驚坐起閱讀 9,939評(píng)論 0 23
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問(wèn)題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,776評(píng)論 0 33
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類(lèi)相關(guān)的語(yǔ)法,內(nèi)部類(lèi)的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線(xiàn)程的語(yǔ)...
    子非魚(yú)_t_閱讀 31,778評(píng)論 18 399
  • 朗月疏星夜色濃,心似關(guān)山數(shù)萬(wàn)重。 同僚言吾身益瘦,可存煩事在胸中?
    明哥明說(shuō)閱讀 267評(píng)論 0 1
  • 昨晚是怎么回去的,我都不太清楚。只覺(jué)得胸口隱隱作痛,雙腿如灌鉛一般。一路上渾渾噩噩,身體不受控制。 我的意識(shí)就是趕...
    談笑No1th閱讀 108評(píng)論 0 0