实战模拟│揭秘为啥年会你抽不到特等奖

简介: 抽奖不只是概率性事件,有可能是确定性事件

一、随机抽奖

  • 随机抽奖当然是最公平的抽奖,就是当用户抽奖时随机返回抽奖结果
  • 这种结果完全随机,不受人为控制,中奖全凭借运气
  • 先定义奖池拥有的奖品,用户进来抽奖后,随机返回奖池中的奖品
<?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 ($prizeas&$item) {
$chance+=$item['chance'];
$item['chance'] =$chance;
}
// 随机抽奖$rand=mt_rand(1, 10000);
$result= [];
foreach ($prizeas$_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;
        }
    }
}
// 抽奖结果echojson_encode(compact('rand', 'result'));


三、内定抽奖

  • 内定抽奖是年会常用的抽奖方式,公司为了奖励那些本年度为公司做过重大贡献的人
  • 选择在年会上将指定奖品通过抽奖的方式送给那些人
  • 不仅能够给那些人带来鼓励,更多的是为了加强公司凝聚力
  • 这种抽奖模式,早先已经将奖品和内定人做了绑定
  • 只有当指定的人进来才可以抽到奖品,其他人都是谢谢参与,但是用户却不知道这种是内定的
<?php$prize= [
    ['name'=>'60寸大彩电', 'winners'=> ['张三']],
    ['name'=>'iphone13', 'winners'=> ['李四', '王五']],
    ['name'=>'戴森吸尘器', 'winners'=> ['亮仔']],
    ['name'=>'索尼微单', 'winners'=> ['李六']],
    ['name'=>'VR眼镜', 'winners'=> ['小明']]
];
// 开始抽奖,这里假如亮仔过来抽// 这里的用户也可以是用户唯一标识$user='亮仔';
$result='谢谢参与';
foreach ($prizeas$item) {
if (in_array($user, $item['winners'])) {
$result=$item['name'];
break;
    }
}
print_r('获得的奖品:' . $result);
相关文章
|
存储 SQL 大数据
列式存储系列(一)C-Store
列式存储系列(一)概述 序 本文是列式存储系列的第一篇。在这个系列中,我们将介绍几个典型的列式存储系统。这些列式系统的出现都有各自的时代背景。在介绍这些系统的同时,我们也尽量介绍一下它们的背景,以便大家有一个更宏观的认识,理解这个系统为什么会出现,它要解决的问题,以及它如何影响后来类似系统的发展。
3155 0
|
程序员
阿里技术高P访谈之“呆萌”程序员蒋晓伟为何从Facebook到阿里巴巴
跟蒋晓伟约在一个下午进行访谈,他的花名叫量仔,这个名号让笔者的第一感觉是“高富帅”。然而,当见到本尊之后,才发现他完全就是一个“呆萌”版的程序员,这也印证了其在阿里巴巴内网上的标签——“头像蛮萌的”。
10532 2
|
编译器
#define 宏定义看这一篇文章就够了
#define 宏定义看这一篇文章就够了
662 0
|
自然语言处理 算法 数据可视化
干货合集│最好用的 python 库都在这
这些有趣的 python 库,可以让你爱上 python
207 4
干货合集│最好用的 python 库都在这
C++11特性之std:call_once介绍
std:call_once是C++11引入的新特性,如需使用,只需要#include <mutex>即可,简单来说std:call_once的作用,确保函数或代码片段在多线程环境下,只需要执行一次,常用的场景如Init()操作或一些系统参数的获取等。
408 0
|
缓存 移动开发 JavaScript
阿里云OSS设置跨域访问
阿里云OSS设置跨域访问
17581 1
|
存储 缓存 算法
倒排索引:ES倒排索引底层原理及FST算法的实现过程(二)
倒排索引:ES倒排索引底层原理及FST算法的实现过程(二)
倒排索引:ES倒排索引底层原理及FST算法的实现过程(二)
|
存储 自然语言处理 算法
倒排索引:ES倒排索引底层原理及FST算法的实现过程(一)
倒排索引:ES倒排索引底层原理及FST算法的实现过程
倒排索引:ES倒排索引底层原理及FST算法的实现过程(一)
|
索引
ElasticSearch _version字段的作用
ElasticSearch _version字段的作用
323 0
|
存储 SQL OLAP
列式存储 vs 行式存储:它们之间的本质区别在哪里?
论文三位作者系统系统解答了列式存储与行式存储的区别,通过实验告诉我们,列式存储是因为其内部架构而具有更好的性能,而不是理所当然的理由——更少的 I/O。不仅仅限于内部架构,查询引擎层的各种优化也同样是列式存储性能提升的关键。
3240 0
列式存储 vs 行式存储:它们之间的本质区别在哪里?