528. 按权重随机选择

528. 按权重随机选择

1. 题目
题目链接

给定一个正整数数组 w ,其中 w[i] 代表位置 i 的权重,请写一个函数 pickIndex ,它可以随机地获取位置 i,选取位置 i 的概率与 w[i] 成正比。
说明:
1 <= w.length <= 10000
1 <= w[i] <= 10^5
pickIndex 将被调用不超过 10000 次
示例1:
输入:
[“Solution”,“pickIndex”]
[[[1]],[]]
输出: [null,0]
示例2:
输入:
[“Solution”,“pickIndex”,“pickIndex”,“pickIndex”,“pickIndex”,“pickIndex”]
[[[1,3]],[],[],[],[],[]]
输出: [null,0,1,1,1,0]
输入语法说明:
输入是两个列表:调用成员函数名和调用的参数。Solution 的构造函数有一个参数,即数组 w。pickIndex 没有参数。输入参数是一个列表,即使参数为空,也会输入一个 [] 空列表。

2. 题目分析
根据权重选择来获取下标,其实这题跟我之前拼多多一轮面试的题目,根据权重负载均衡到某一台魂村服务器上的意思是一样的,只是不要求平滑的均衡分布。

3. 解题思路
可以将概率转换成几何问题,即将权重用线段长度表示,或者说用一个区间表示一个权重,然后在整个集合范围内随机生成一个数,查看这个数在哪个区间,那么就返回这个区间对应的数字即可。
如,权重:[1,2,3,4],则
可以用区间(左开右闭区间): [1,2), [2, 4), [4,7), [7, 11)
那么我们可以在[1-10]之间生成随机数,然后看随机数在哪个区间,比如说,随机数为6,则在区间 [4,7),那么返回区间所在的下标3。
那么问题来了,我们怎么找到随机数所在的区间呢?顺序遍历肯定是OK的,时间复杂度为O(n),但有没有更高效率的算法呢?我们发现区建设hi有序的,有序的查找值,最常见的算法就是二分查找了,yes,就是优化后的思路,就是通过二分法来查找所在的区间。

4. 代码实现(java)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值