自己写了一个红包生成算法 可以正确生成 缺无法递归出来?
由于要生成随机红包,并且需要设置要发放红包的 金额、最小值、最大值、以及数量。
我尝试了 用for循环,但是会卡在 do while 这里, 所以用递归写了一个,内存中可以生成正确的红包,但是无法递归出来。请大牛帮忙看下问题 出在哪里?
<code><?php //调试函数 function p($arr) { echo "<pre class="brush:php;toolbar:false">" . print_r($arr, true) . "</code>
回复内容:
由于要生成随机红包,并且需要设置要发放红包的 金额、最小值、最大值、以及数量。
我尝试了 用for循环,但是会卡在 do while 这里, 所以用递归写了一个,内存中可以生成正确的红包,但是无法递归出来。请大牛帮忙看下问题 出在哪里?
<code><?php //调试函数 function p($arr) { echo "<pre class="brush:php;toolbar:false">" . print_r($arr, true) . "</code>
我按照你给的改的:
<?php //调试函数 function p($arr) { echo "<pre class="brush:php;toolbar:false">" . print_r($arr, true) . "
注意由于你用的是递归, 而且是按照运气的随机很容易堆栈溢出,
我测试了一下你的数据luckymoney(80, 1.3, 2, 50) 5次大概成功2次,建议你改算法.....
return hongbao($money, $min, $max, $num, $arr, 'no');
谢谢大家,我重新用 for循环改进了一下算法。
按发 200元 最小1.3 最大3 发200个红包来计算
用for循环算法 ,函数执行100次 平均每次 执行时间为 0.004秒
用递归算法,函数执行100次,平均每次执行时间为 0.211秒
效率相差 52.75倍 上代码 谢谢@aristotll 给的建议
下面是 for循环代码,如果大家有更好的思路 请指导我一下,谢谢
<?php
//调试函数
function p($arr)
{
echo "<pre class="brush:php;toolbar:false">" . print_r($arr, true) . "</pre><div class="contentsignin">登录后复制</div></div>";
}
//发红包函数
function hongbao($money, $min, $max, $num)
{
$arr = array();
//由于红包是以分为单位所以先转换单位,1元=100分,但只需转换一次
$money = $money * 100;
$min = $min * 100;
$max = $max * 100;
//红包发放最大最小值合法性检测,防止发送死循环
if ($money - $min * $num < 0) {
return "你发放红包的金额太小不足以 发给这么多人";
} else {
if ($money - $max * $num > 0) {
return "你发放红包的金额太大 这些人领不完";
}
}
$tempnum = $num;
for ($i = 0; $i < $tempnum; $i++) {
$flag = 'no';
do {
//随机生成一个红包
$rand = mt_rand($min, $max);
$anum = count($arr);
$zx = $money - array_sum($arr) - $rand - ($num - 1) * $min;
$zd = $money - array_sum($arr) - $rand - ($num - 1) * $max;
$all = array_sum($arr);
if ($zx >= 0 && $zd <= 0) {
$arr[] = $rand;
$flag = 'yes';
$num--;
}
} while ($flag == 'no');
}
shuffle($arr);
return $arr;
}
$myarr = hongbao(200, 1, 3, 100);
p($myarr);
echo array_sum($myarr)/100;

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

登录 CakePHP 是一项非常简单的任务。您只需使用一项功能即可。您可以记录任何后台进程(如 cronjob)的错误、异常、用户活动、用户采取的操作。在 CakePHP 中记录数据很容易。提供了 log() 函数
