码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode 528. Random Pick with Weight

时间:2019-08-04 16:50:09      阅读:69      评论:0      收藏:0      [点我收藏+]

标签:while   生成   param   ant   div   object   index   tco   log   

给一个权重的vector,让你根据权重的概率返回值,返回的值是这些权重的索引。

比如给你一个[1,2]的权重矩阵,1/3的概率返回0,2/3的概率返回1。

等概率函数random只能等概率的一系列数,所以需要将权重矩阵进行累加,即[1,2]变成[1,3],这样如果你用random生成的等概率数是0,就属于第一个权重;如果生成的等概率数是1、2,就属于第二个等概率数。

可以看到其实就是用二分查找找第一个大于用random生成的数。

 

class Solution {
public:
    Solution(vector<int>& w) {
        sum = w;
        for(int i = 1;i < w.size();i++){
            sum[i] = sum[i-1] + w[i];
        }
    }
    
    int pickIndex() {
        int num = sum[sum.size() - 1];
        int index = random()%num;
        int left = 0,right = sum.size() - 1;
        while(left < right){
            int mid = left + (right - left)/2;
            if(sum[mid] <= index)
                left = mid + 1;
            else
                right = mid;
        }
        return right;
    }

    vector<int> sum;
};

/**
 * Your Solution object will be instantiated and called as such:
 * Solution* obj = new Solution(w);
 * int param_1 = obj->pickIndex();
 */

 https://www.cnblogs.com/grandyang/p/9784690.html

leetcode 528. Random Pick with Weight

标签:while   生成   param   ant   div   object   index   tco   log   

原文地址:https://www.cnblogs.com/ymjyqsx/p/11298643.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!