用PHP如何实现抽奖系统,抽奖设置有几种
Admin 2022-08-02 群英技术资讯 1033 次浏览
这篇文章给大家分享的是“用PHP如何实现抽奖系统,抽奖设置有几种”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。随机抽奖当然是最公平的抽奖,就是当用户抽奖时随机返回抽奖结果
这种结果完全随机,不受人为控制,中奖全凭借运气
先定义奖池拥有的奖品,用户进来抽奖后,随机返回奖池中的奖品
<?php $prize = ['60寸大彩电', 'iphone13', '戴森吸尘器', '索尼微单', 'VR眼镜', '谢谢参与']; // 当有用户进来抽奖,进行随机抽奖 shuffle($prize); // 抽奖结果 print_r($prize[0]);
概率抽奖,其实就是给奖品设置概率,一般高价值的奖品会设置中奖的概率极低
这种抽奖也是随机抽奖的一种,但是并没有上面那种没有概率控制的随机抽奖
抽中特等奖是需要极大的运气成分的,大多数人都会抽奖价值低的奖品
<?php
$prize = [
['name' => '60寸大彩电', 'chance' => 100],
['name' => 'iphone13', 'chance' => 900],
['name' => '戴森吸尘器', 'chance' => 1000],
['name' => '索尼微单', 'chance' => 2000],
['name' => 'VR眼镜', 'chance' => 3000],
['name' => '谢谢参与', 'chance' => 3000]
];
// 概率重组
$chance = 0;
foreach ($prize as &$item) {
$chance += $item['chance'];
$item['chance'] = $chance;
}
// 随机抽奖
$rand = mt_rand(1, 10000);
$result = [];
foreach ($prize as $_k => $_v) {
if ($_k == 0) {
if ($rand > 0 && $rand <= $_v['chance']) {
$result = $_v;
break;
}
} else {
if ($rand > $prize[$_k - 1]['chance'] && $rand <= $_v['chance']) {
$result = $_v;
break;
}
}
}
// 抽奖结果
echo json_encode(compact('rand', 'result'));
内定抽奖是年会常用的抽奖方式,公司为了奖励那些本年度为公司做过重大贡献的人
选择在年会上将指定奖品通过抽奖的方式送给那些人
不仅能够给那些人带来鼓励,更多的是为了加强公司凝聚力
这种抽奖模式,早先已经将奖品和内定人做了绑定
只有当指定的人进来才可以抽到奖品,其他人都是谢谢参与,但是用户却不知道这种是内定的
<?php
$prize = [
['name' => '60寸大彩电', 'winners' => ['张三']],
['name' => 'iphone13', 'winners' => ['李四', '王五']],
['name' => '戴森吸尘器', 'winners' => ['亮仔']],
['name' => '索尼微单', 'winners' => ['李六']],
['name' => 'VR眼镜', 'winners' => ['小明']]
];
// 开始抽奖,这里假如亮仔过来抽
// 这里的用户也可以是用户唯一标识
$user = '亮仔';
$result = '谢谢参与';
foreach ($prize as $item) {
if (in_array($user, $item['winners'])) {
$result = $item['name'];
break;
}
}
print_r('获得的奖品:' . $result);
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文并没有kafka的安装教程,本文是针对已经安装kafka及其配置好kafka的php拓展并且使用laravel框架进行开发项目,配置一个可供laravel框架使用的生产及消费者类,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇文章能帮助大家解决问题。
在laravel中,with()方法是用作“渴求式加载”,表示laravel将会伴随着主要模型预加载出确切的的关联关系,使用该方法能够缓解“1+N”的查询问题,仅需“1+1”次查询就能解决问题。
本文主要介绍了laravel修改用户模块的密码验证实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
许多人在学习C语言的时候都写过一些有趣的算法,其实这些算法在PHP中也同样可以实现,甚至有些算法的代码比C语言中还要简洁,需要的朋友可以参考下
我们先来分析下规律。设定总金额为10元,有N个人随机领取:N=1第一个则红包金额=X元;N=2第二个为保证第二个红包可以正常发出,第一个红包金额=0.01至9.99之间的某个随机数。第二个红包=10-第一个红包金额;N=3第三个红包1=0.01至9.99之间的某个随机数红包2=0.01至(10-红包1-0.01)的某个随机数红包3=10-红包1-红包2……于是我们得到
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008