从N个数里面,随机抽取M个数(可以用作抽奖随机用户)
来源:互联网 发布:spark mongodb java 编辑:程序博客网 时间:2024/05/17 03:01
从62个人随机抽取10个人
直接抽取
上面这个方法非常直观,首先生成一个顺序的 1 ~ 62 号的数组,然后从其中随机抽取 10 次,为了不重复,将抽取的数字通过 cards.splice(idx, 1)
从原数组中取出来。
上面这种方式可行,但它不是最好的,因为每次 splice 一个数字,取 10 个数字需要 splice 10 次,这看起来不是特别好。可以想到另一种方法,先对数组进行“洗牌”,然后一次把 10 个数字取出来:
先洗牌
上面这个版本是月影实际现场写出的(略有修改),它是不错的,但是它也有明显缺点。首先它先把所有的牌都排序了,但实际上只需要排序 10 张牌就好,多余的排序没有必要。其次,它不方便连续抽奖,比如第一次抽取 10 个号,然后再想多抽取 5 个号,它就做不到了。
我们先解决第一个问题:
不需要洗所有的牌
上面这个版本是优化过的版本,显然如果取 10 个数,只需要循环 10 次即可,不需要把 64 张牌都洗了。
要解决可以连续抽奖的问题,就需要把 cards 提取出来(就像方案 1 的随机抽取一样),但是那样的话就使得函数有副作用,虽说是临时写一个抽奖,也不喜欢设计得太糙。或者,那就加一个构造器执行初始化?
构造器负责初始化
更优雅的解决方式?
实际上,对于一次可能抽取任意多个获奖人的场景,用 ES6 的 generators 非常合适,我们可以直接拿洗牌的版本略做修改:
最后补充一个小技巧,利用 Array(n).fill().map(...)
可以方便快速地构造数组:
阅读全文
0 0
- 从N个数里面,随机抽取M个数(可以用作抽奖随机用户)
- 从1到m随机n个数
- 从N个数总随机选出M个数
- 从M个数中随机选出N个数的所有组合,无序,(一)
- 从M个数中随机选出N个数的所有组合,有序,(二)
- 从n个数中随机选取m个
- 关于从n个数中随机取出m个
- 30 从n个数中随机获取m个数字
- 从n个数中选择随机选择m个, m个数互不重复
- 从1-n这n个数里面,随机选出若干个数,使之和为sum
- 从数据流中随机取m个数
- 从数据流中随机取m个数
- 想一想如何从M个数中随机等可能的取出N个数
- 深搜 从n个数中随机选取m个数 求出所有组合的和 模版
- Java中从m个数中随机选取n个不同的数(m>=n),并进行排序
- n个数中随机产生不重复的m个数
- m个数随机取n个数的java实现
- 随机生成n个数
- PAT考试乙级1013(C语言实现)
- Java8 Comparator
- 第一章 SpringCloud概要
- 第三章、网络访问层
- nginx部署
- 从N个数里面,随机抽取M个数(可以用作抽奖随机用户)
- 从上往下打印二叉树
- 在 Spring Boot @Configuration 注解类中使用 Mybatis 查询数据库启动报错
- android 保存logcat信息到本地文件中
- c#读取,修改配置信息,并连接数据库代码测试
- 创建与合并分支
- js城市菜select菜单联动包
- const T、const T*、T *const、const T&、const T*& 的区别
- Exception in thread "main" redis.clients.jedis.exceptions.JedisConnectionException: java.net.SocketT