Maison > développement back-end > tutoriel php > 关于定时刷票的一个算法问题

关于定时刷票的一个算法问题

WBOY
Libérer: 2016-06-23 14:20:40
original
1219 Les gens l'ont consulté

关于一个定时刷票的问题,场景如下:
某个时段内投N个票,如设置一个小时刷2000张票!则一小时内会多次对其投票,且每次投票的数量是随机的(当然总投票数量不能超过刚才说的总数2000),如何将其分解成一条条的任务呢。

如:
1. 10点投5票
2. 10点零9分投7票
3. 10点20分投200票
4. 10点22分投10票
5. 。。。。
6. 11点投N分。

谢谢!


回复讨论(解决方案)

思路

total = 2000; //总数$num = 20; //批数for($i=0; $i<$num; $i++) {  if($total) {    $n = $i+1 == $num ? $total : rand(0, $total*($i+1)/$num);    echo $n, PHP_EOL;    $total -= $n;  }}
Copier après la connexion

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal