突發奇想給校友微信群發了紅包,我設定紅包總額為10元,支援28個人隨機領取。
於是一個有趣的結果出現了:
A 領了 0.26元
B 領了 0.29元
C 領了 0.02元
D 領了 0.56元
E 領了 0.64元
……
微信是採用什麼樣的演算法做到的?簡單百度了下,目前尚未有官方的說明,僅僅在知乎裡有一個較為熱門的討論,鏈接戳這裡,不過他們討論的太過於深入,有掉坑之嫌。
我按照自己的邏輯嘗試了下,這個演算法需要滿足以下幾點要求:
1、每個人都要能夠領取到紅包;
2.每人領取到的紅包金額總和=總金額;
3.每個人領到的紅包金額不等,但也不能差的太離譜,不然就沒趣味;
4.演算法一定要簡單,不然對不起騰訊這個招牌;
在正式編碼之前,先搭建一個遞進的模型來分析規律
設定總金額為10元,有N個人隨機領取:
N=1
則紅包金額=X元;
N=2
為保證第二個紅包可以正常發出,第一個紅包金額=0.01至9.99之間的某個隨機數
第二個紅包=10-第一個紅包金額;
N=3
紅包1=0.01至0.98之間的某個隨機數
紅包2=0.01至(10-紅包1-0.01)的某個隨機數
紅包3=10-紅包1-紅包2
……
至此,規律出現囉!開始編碼!
Php代碼
header("Content-Type: text/html;charset=utf-8");//输出不乱码,你懂的 $total=10;//红包总额 $num=8;// 分成8个红包,支持8人随机领取 $min=0.01;//每个人最少能收到0.01元 for ($i=1;$i<$num;$i++) { $safe_total=$total-($num-$i)*$min;//随机安全上限 $money=mt_rand($min*100,$safe_total*100)/100; $total=$total-$money; echo '第'.$i.'个红包:'.$money.' 元,余额:'.$total.' 元 <br/>'; } echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';
輸入一看,波動太大,這數據太無趣了!
第1個紅包:7.48 元,餘額:2.52 元
第2個紅包:1.9 元,餘額:0.62 元
第3個紅包:0.49 元,餘額:0.13 元
第4個紅包:0.04 元,餘額:0.09 元
第5個紅包:0.03 元,餘額:0.06 元
第6個紅包:0.03 元,餘額:0.03 元
第7個紅包:0.01 元,餘額:0.02 元
第8個紅包:0.02 元,餘額:0 元
改良一下,將平均值當作隨機安全上限來控制波動差
Php代碼
header("Content-Type: text/html;charset=utf-8");//输出不乱码,你懂的 $total=10;//红包总额 $num=8;// 分成8个红包,支持8人随机领取 $min=0.01;//每个人最少能收到0.01元 for ($i=1;$i<$num;$i++) { $safe_total=($total-($num-$i)*$min)/($num-$i);//随机安全上限 $money=mt_rand($min*100,$safe_total*100)/100; $total=$total-$money; echo '第'.$i.'个红包:'.$money.' 元,余额:'.$total.' 元 <br/>'; } echo '第'.$num.'个红包:'.$total.' 元,余额:0 元';
輸出結果見下圖
第1個紅包:0.06 元,餘額:9.94 元
第2個紅包:1.55 元,餘額:8.39 元
第3個紅包:0.25 元,餘額:8.14 元
第4個紅包:0.98 元,餘額:7.16 元
第5個紅包:1.88 元,餘額:5.28 元
第6個紅包:1.92 元,餘額:3.36 元
第7個紅包:2.98 元,餘額:0.38 元
第8個紅包:0.38 元,餘額:0 元
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

PHP日誌記錄對於監視和調試Web應用程序以及捕獲關鍵事件,錯誤和運行時行為至關重要。它為系統性能提供了寶貴的見解,有助於識別問題並支持更快的故障排除

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境