如题。

Ramdom 完事

随机数完事

随会在乎公平呢(狗头)

大奖为 0 ,其他随机

彩票怎么写就怎么写

// 就算没有中奖也有 20%概率发送弹幕,产生一种中奖的人很多的错觉

if(name=='张三') return 一等奖
if(name=='李四') return 二等奖
return 谢谢参与

一般抽奖程序就和平常抽奖程序一样写就行了。

兄弟你是腾讯来的吧 笑死

听君一席话

提前分配中奖者

print("谢谢参与")

取决于想模拟的随机分布模型

兄弟,你这...可不可以在张三前面给我加个特等奖

有一次抽奖 (iPhone),领导抽了第一个人,说名字写的太潦草,看不清,扔回去重新抽了第二个人,谁会关心名字是否太潦草呢?

下一年抽奖 (MBA),大家下面起哄谁谁谁今天生日,还是同一个领导抽奖,很幸运过生日的人中奖了。

按领导意思处理,如果是面对互联网肯定是内定,如果是内部的话高管要避嫌

看需求,再选择随机算法

之前做了一个,让运营人员上传 excel ,表格填中奖序号和奖品。

服务器机房安装一个话筒,根据当时录音的声波值 hash ,然后用 hash 值做随机数种子,然后使用随机函数

绝对随机算法😏

先准备员工姓名工号列表,作为第一个列表,如果特等奖有内定,则把特等奖那个员工从第一个列表中摘出来单独放一个列表,如果有一等奖内定,则把一等奖那个员工也从列表中摘出来单独放一个列表,以此类推。如果有员工黑名单或者高管或者避嫌不想让中奖的人,则把这些人从第一个列表中移除。
现在可供抽奖的员工列表准备完毕了,再准备一个列表(员工姓名、工号、头像)供界面滚动,这个列表包含公司全体员工,让每个人(包括老板)都可以在界面上滚动,这个列表是死的,不论是否中过奖,不论是否是内定,都在里面滚动。
下面开始抽奖,三等奖和二等奖抽的时候,可以使用洗牌算法进行抽取,洗牌算法随便百度就有现成的代码,抽到哪些人,就把他们从第一个列表中移除,单独放入中奖列表,记录下这些人的中奖信息。抽一等奖时要注意,一定要先拉取内定人员列表,再从剩下的列表中抽取,如果一次抽取很多人,这些人在界面上的排序要随机,不要连着。

之前参与过一次讨论,确实不只是 Ramdom 那么简单。主要是不能确定抽奖总次数(总人数)。
一般简单的需求只是提出了中奖概率:一等奖中奖率 1%,二等 3%,三等 5%,为了方便讨论,姑且再简单化每个奖项奖品数量为 1 。
然后大多数人一上来的写法就是 random1~100 ,然后得出指定的一个或者多个的数,来做中奖判断。
实际上这种简单模型,只遵循了理论上的中奖率,没有符合到实际需求。因为中奖变得“先到先得”更为重要了(可以写个模拟抽奖 demo 测试一下),但实际上一场抽奖活动更多的是希望吸引更多的人流,并不想活动开了半天大奖全部抽完。
所以当时我盲猜两种做法:1 极度调低实际的中奖率,配合活动结束时间稍微调整让奖品都能送出; 2 也是要配合活动时间定时定量动态调整奖品中奖率。

我用的是 Alias Method. 运行一年多 基本上的结果都和设定的概率趋同.

没用,获取声波就大有可操作的地方,毕竟人脑也不可能判断你取得参数是否正确。要想做到真正公平,就必须流程公开人人可计算,例如遵循密码学承诺的开奖方式

彩票不是随机的,如果真随机早就做不下去了

我觉得还是要看功能吧,之前有一个什么星 yun 抽奖的,你看它实现的功能再定制你自己需要的功能啊

时间戳做随机种子,还要策划要求的保底功能,欧皇靠概率防不住。

大一的时候给学校的活动做过大屏抽奖,主要是根据场地大小预估场地人数,确保性能跟得上
提供一个二维码链接供用户扫码输入信息,输入的信息会通过 websocket 传到浏览器端,采用 websocket 的主要原因是当时的服务器宽带太小,怕人数多了太卡,等于把大流量的下载变成分散的小流量。
浏览器端设置一个 strat/stop 方法,控制滚动
滚动很简单,就是取随机数去改变文字,实测在 70ms 左右效果就不错

同时可以提供一个控制端,通过 websocket 控制大屏幕的开始或暂停
当然如果想省事,直接设置快捷键,后台工作人员根据主持人的指示 start/stop 即可

这是大屏抽奖,中奖率啥的没考虑,因为本身是各奖项数量有限,没有必要去考虑,不过有一个去重,即中奖后会把他从名单拿掉,防止万一重复中奖造成他人眼红。。

如果参与人数比较多同时想控制出奖均匀,可以采取定点放奖。这样某个时间一到,第一个抽的人就拿走相应的奖。

甚至由运营人员点按钮,人工放大奖。点了大奖马上就放池子里,第一个抽者获得

彩票是官营博彩,真随机没办法控制

把中奖名额设置可以指定 然后问问老板意思

return "谢谢参与"

网页滚动:
随机姓名 随机号码 刚刚中了 XXX ,运气爆表!!!
...

1 、黑名单、白名单。
2 、时间做种子,如果系统有其他业务的话,可以加一些其他业务的无关信息。(比如昨天某某日志的条数)
3 、根据业务需要增加保底和概率回归(因为抽奖都是有限次的,所以有可能会导致当场抽奖的概率和理论概率有很大偏差)

是的,总得有人吃肉,有人喝汤,有人提供案板,有人自愿躺在上面

一般内定,然后整个滚动的假象。

每个用户能拿什么奖,事先打好标,一般一个 int 就够了,然后实际抽的时候在对应的人群里选人出来就行

不能不怀疑,有些起哄的人写了过生日的人的名字,属于拔高中奖率了

?你是不是不懂彩票这东西越随机越能赚钱?

应该用一个难以控制,但是容易验证的值作为 seed
比如说,提前约定未来某天的 股指收盘点数

把老板指定的人放置好,放点甲乙丙丁假人,最后把自己的控制的代理人也放进去,行啦

public static void main(String[] args) {
WeightRandom weightRandom = WeightRandom.create();
weightRandom.add("奖品 1", 0.8);
weightRandom.add("奖品 2", 0.2);
weightRandom.add("谢谢参与", 0);

// 统计 (这里用 AtomicInteger 仅仅是因为写起来比较方便,这是一个单线程测试)
Map<String, AtomicInteger> statistics2 = new HashMap<>();

for (int i = 0; i < 1_0; i++) {
String award = weightRandom.next();
System.out.println(award);
statistics2.computeIfAbsent(award, (k) -> new AtomicInteger()).incrementAndGet();
}
statistics2.forEach(
(k, v) -> {
double hit = (double) v.get() / 1_0;
System.out.println(k + ", hit:" + hit);
});
}


cn.hutool
hutool-all
${hutool}

实现概率抽奖,请叫我雷锋

github.com/vitozyf/lucky-draw.git

以前写过一个

有个后台,由运营配置 奖品和库存, 然后根据库存来计算中奖概率

所以 一等奖的 iPhone 的库存是 0,所以这个就不会抽中,但是会在抽奖列表里

概率是这么算的(是想公平点......)

就是随机值

比如 所有奖项库存是 100
一等奖是 iPhone,库存 0, 所以 概率就是 0
二等奖库存 10 个, 概率就是 10%
三等奖库存 40 个,概率就是 40%
四等奖库存 50 个,概率就是 50%

那么第一个人抽, 随机值是从 (0,100]
如果随机值是 (0,10] 就是二等奖
如果随机值是[11,50] 就是三等奖
如果随机值是[51,100]就是四等奖

第一个人抽中后,库存减一,比如 是抽中二等奖

那么 接下来的人
二等奖范围[0,9]
三等奖[10,49]
四等奖[50,99]

这样每个奖品都有库存.. 还可以随时加库存..

另外,如果有 谢谢惠顾 也是按照一种奖品来设置的. 不过他的奖品 ID 是特定的, 因为它的库存是无限的, 数据库里是有限的,如果不够了,代码会自动补货....
然后就是 缓存和数据库的事情了

以前的伪代码: interview.wzcu.com/%E8%AE%BE%E8%AE%A1%E9%A2%98/%E5%B8%A6%E6%9C%89%E6%9D%83%E9%87%8D%E7%9A%84%E9%9A%8F%E6%9C%BA%E7%AE%97%E6%B3%95.html#%E4%BB%A3%E7%A0%81
主要以前量小, 基本问题不大...

if (试用期) return
if (3 年一下) return 阳光普照

众所周知,对于新浪微博来说,任何抽奖都要加一条 user.gender != "M" 。

Random
中 2 等奖,库存 -1 ,没了 算中 3 等奖,往下推。

类似卡池...

核心就是随机函数,要有人还要继续深究真随机还是假随机,直接让他出随机方案. GG

“要有人还要继续深究真随机还是假随机”

这种只能是假随机,就好比游戏氪金一样。在程序员真随机数大数据看来,没问题。可是由于人性的干预,很多人就觉得十连抽,一个 SSS 都不中,就觉得很离谱。又或者 20 连抽后,连续两个 SS 挤在一起。

假随机给用户的感觉更好。其实随机数还是那些,就是加入了十年抽必中,在给用户结果前,已经后台预先排序过了。

概率可配置,例如根据标签配置概率,如 [优质] 标签中奖概率调高, [新注册] 用户概率调极低之类的,反正就是要提供运营一套她们想让谁中就让谁中的配置化系统。