跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 一般的抽奖程序是怎么写的?
未分類
24 12 月 2021

一般的抽奖程序是怎么写的?

一般的抽奖程序是怎么写的?

資深大佬 : kikione 22

如题。

大佬有話說 (51)

  • 資深大佬 : xiaoyukid

    Ramdom 完事

  • 資深大佬 : potato1949

    随机数完事

  • 資深大佬 : lqw3030

    随会在乎公平呢(狗头)

  • 資深大佬 : long2ice

    大奖为 0 ,其他随机

  • 資深大佬 : aliveyang

    彩票怎么写就怎么写

  • 資深大佬 : 2i2Re2PLMaDnghL

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

  • 資深大佬 : HelloWorld556

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

  • 資深大佬 : markgor

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

  • 資深大佬 : Saxton

    @long2ice 兄弟你是腾讯来的吧 笑死

  • 資深大佬 : Junh

    @markgor 听君一席话

  • 資深大佬 : zjsxwc

    提前分配中奖者

  • 資深大佬 : cjpjxjx

    print(“谢谢参与”)

  • 資深大佬 : laqow

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

  • 資深大佬 : arnoldxiao

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

  • 資深大佬 : jorneyr

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

  • 資深大佬 : jorneyr

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

  • 資深大佬 : murmur

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

  • 資深大佬 : newmlp

    看需求,再选择随机算法

  • 資深大佬 : amwyyyy

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

  • 資深大佬 : sadfQED2

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

  • 資深大佬 : jptx

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

  • 資深大佬 : raysonlu

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

  • 資深大佬 : emeab

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

  • 資深大佬 : rekulas

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

  • 資深大佬 : stroh

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

  • 資深大佬 : necodba

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

  • 資深大佬 : HQKM

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

  • 資深大佬 : y0bcn

    大一的时候给学校的活动做过大屏抽奖,主要是根据场地大小预估场地人数,确保性能跟得上
    提供一个二维码链接供用户扫码输入信息,输入的信息会通过 websocket 传到浏览器端,采用 websocket 的主要原因是当时的服务器宽带太小,怕人数多了太卡,等于把大流量的下载变成分散的小流量。
    浏览器端设置一个 strat/stop 方法,控制滚动
    滚动很简单,就是取随机数去改变文字,实测在 70ms 左右效果就不错
    同时可以提供一个控制端,通过 websocket 控制大屏幕的开始或暂停
    当然如果想省事,直接设置快捷键,后台工作人员根据主持人的指示 start/stop 即可
    这是大屏抽奖,中奖率啥的没考虑,因为本身是各奖项数量有限,没有必要去考虑,不过有一个去重,即中奖后会把他从名单拿掉,防止万一重复中奖造成他人眼红。。

  • 資深大佬 : Chad0000

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

  • 資深大佬 : Chad0000

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

  • 資深大佬 : securityCoding

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

  • 資深大佬 : Immortal

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

  • 資深大佬 : geekvcn

    return “谢谢参与”
    网页滚动:
    随机姓名 随机号码 刚刚中了 XXX ,运气爆表!!!
    …

  • 資深大佬 : kop1989

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

  • 資深大佬 : stroh

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

  • 資深大佬 : SmiteChow

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

  • 資深大佬 : soupu626

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

  • 資深大佬 : 2i2Re2PLMaDnghL

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

  • 資深大佬 : 2i2Re2PLMaDnghL

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

  • 資深大佬 : mengyx

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

  • 資深大佬 : coolmenu

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

  • 資深大佬 : jinzhongyuan

    public static void main(String[] args) {
    WeightRandom<String> 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);
    });
    }
    <dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>${hutool}</version>
    </dependency>
    实现概率抽奖,请叫我雷锋

  • 資深大佬 : vitozyf

    https://github.com/vitozyf/lucky-draw.git

  • 資深大佬 : ylsc633

    以前写过一个
    有个后台,由运营配置 奖品和库存, 然后根据库存来计算中奖概率
    所以 一等奖的 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 是特定的, 因为它的库存是无限的, 数据库里是有限的,如果不够了,代码会自动补货….
    然后就是 缓存和数据库的事情了
    以前的伪代码: http://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
    主要以前量小, 基本问题不大…

  • 資深大佬 : a62527776a

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

  • 資深大佬 : fl2d

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

  • 資深大佬 : wolfie

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

  • 資深大佬 : dbpe

    类似卡池…

  • 資深大佬 : tzigone

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

  • 資深大佬 : 3dwelcome

    “要有人还要继续深究真随机还是假随机”
    这种只能是假随机,就好比游戏氪金一样。在程序员真随机数大数据看来,没问题。可是由于人性的干预,很多人就觉得十连抽,一个 SSS 都不中,就觉得很离谱。又或者 20 连抽后,连续两个 SS 挤在一起。
    假随机给用户的感觉更好。其实随机数还是那些,就是加入了十年抽必中,在给用户结果前,已经后台预先排序过了。

  • 資深大佬 : Alchemistboy

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

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具