• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > 想了解微博的抽奖系统算法

想了解微博的抽奖系统算法

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了微博算法,推荐系统算法,人脸识别系统算法,排课系统算法,操作系统算法等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:想了解微博的抽奖系统算法
描述:

最近公司要做一个抽奖系统,抽奖源数据量不到1000(数据包括姓名、手机号、所属部门)。
共5个奖项,每一奖项至少5人,可能还有特等奖,当然这些都是已知的。
我现在想到的是,一次性取出所有数据的唯一ID,然后抽每一个奖项的每一个人都随机一次(这样应该更公平吧?),抽完一次后更新已经抽出的人的状态,取出数据展现,接着继续。

问:
1、总感觉这样的算法不太合适,是否有更好的算法?
2、像新浪微博的转发抽奖系统,数据量可能几十万到几百万,显然上面的算法是不合适的,不知道是怎么样一种算法?


解决方案1:

1. 你的需求其实很简单,就是从N个元素中随机抽取k个,并且要尽量保证每个元素被抽中的概率都是k/N。最简单的办法就是将这N个元素存在一个数组中,随机打乱(保证每个元素出现在每个位置的概率都相同),然后选取前k个就行。具体的算法,直接用stl algorithm里的random_shuffle,或者参考这里

2. 对于微博这种转发抽奖系统,其难度在于
(1) N很大
(2) N未知
如果是在活动结束后才给出所有中奖结果,那么就可以采用一种叫做“蓄水池抽样”的算法,时间复杂度O(N)(扫一遍),空间复杂度O(k),从数学上可以保证(只要随机数发生器是真随机),每一个元素中奖的概率是 k/N。具体的算法网上一搜就能看到,不细说了。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 想了解微博的抽奖系统算法
  • 微博热门的排序算法

相关文章

  • 2017-06-07 日志分析无法匹配内容
  • 2017-06-07 Shell里如何过滤出文件中匹配某个规则的行以及它上面的注释行
  • 2017-06-07 Jboss711部署JPA在WEB项目不可正常调用
  • 2017-06-07 (golang)go语法里&符号用法?
  • 2017-06-07 LaravelLog模块设计
  • 2017-06-07 互斥是不是一个系统级别的变量
  • 2017-06-07 关于++运算符的困惑。
  • 2017-06-07 请问怎么测试七牛的CDN
  • 2017-06-07 laravel中有多个数据库,ORM如果使用多个数据库?
  • 2017-06-07 打印东西老是出笑脸或者红心怎么回事

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 求大神指点,关于paramiko方面有地方不知道怎么处理
    • Python字符串解析
    • python类中出现NameError的问题
    • 两条直线被第三条直线所截怎样在C++里面初始化两条链表?
    • javaredis同一时间限制同一ip登陆
    • python生成快速的文件
    • flaskflask有句话不是太懂?
    • github的新用户是不是用不了pages了?
    • 请教peewee与异步mysql库tornado_mysql的整合问题
    • [Kutoteki]ACG兴趣小组招募前端

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有