不重复的加权随机抽样数组项
创始人
2025-01-12 12:30:27
0

以下是一个示例的解决方法,使用Python语言实现:

import random

def weighted_random_sampling(arr, weights, k):
    # 创建一个字典,用于存储数组项及其权重
    weighted_items = {item: weight for item, weight in zip(arr, weights)}
    
    # 创建一个空列表,用于存储抽样结果
    sampled_items = []
    
    # 执行k次抽样
    for _ in range(k):
        # 计算所有数组项的权重总和
        total_weight = sum(weighted_items.values())
        
        # 随机生成一个权重值,范围为0到总权重值
        random_weight = random.uniform(0, total_weight)
        
        # 遍历数组项及其权重
        for item, weight in weighted_items.items():
            # 如果随机权重值小于当前项的权重值,则将该项加入抽样结果列表,并从字典中移除
            if random_weight < weight:
                sampled_items.append(item)
                del weighted_items[item]
                break
            # 如果随机权重值大于等于当前项的权重值,则减去当前项的权重值,继续遍历下一项
            random_weight -= weight
    
    return sampled_items

# 示例用法
arr = ['A', 'B', 'C', 'D', 'E']
weights = [0.1, 0.4, 0.2, 0.2, 0.1]
k = 3

sampled_items = weighted_random_sampling(arr, weights, k)
print(sampled_items)

以上代码中,weighted_random_sampling函数接受三个参数:数组arr、权重数组weights和抽样数量k。该函数使用字典weighted_items存储数组项及其权重,并根据权重进行加权随机抽样。抽样结果存储在列表sampled_items中,并返回该列表。

示例用法中,数组arr包含了五个项,对应的权重数组weights中包含了每个项的权重。k指定了要抽样的数量。输出结果将会是一个长度为k的列表,包含了从数组中加权随机抽样得到的项。

相关内容

热门资讯

黑科技免费(德扑之星app)德... 黑科技免费(德扑之星app)德州机器人固有是有挂!太嚣张了原本是有挂(2026已更新)(哔哩哔哩);...
黑科技好牌(智星德州菠萝)aa... 1、黑科技好牌(智星德州菠萝)aaPOKER好像是真的有挂!太离谱了其实是有挂(2026已更新)(哔...
黑科技玄学(aapoker能玩... 黑科技玄学(aapoker能玩)wepower德州本来是有挂!太离谱了素来是真的有挂(2026已更新...
黑科技新版(poker)德州原... 黑科技新版(poker)德州原本存在有挂!太实锤了真是有挂(2022已更新)(哔哩哔哩)相信很多朋友...
黑科技挂(aa poker辅助... 黑科技挂(aa poker辅助软件)德州wepower本来有挂!太离谱了好像是真的有挂(2023已更...
黑科技好友房(Wepokepl... 黑科技好友房(Wepokeplus)wpK果然是有挂!太夸张了都是是有挂(2022已更新)(哔哩哔哩...
黑科技新版(Wepoke开发)... 黑科技新版(Wepoke开发)聚星扑克本来有挂!太无语了一贯存在有挂(2025已更新)(哔哩哔哩)准...
黑科技脚本(扑克世界app)a... 黑科技脚本(扑克世界app)aapokER一贯存在有挂!太实锤了从前真的是有挂(2025已更新)(哔...
黑科技智能ai(德州之星app... 黑科技智能ai(德州之星app安卓版)AApoker素来真的有挂!太无语了往昔是有挂(2024已更新...
黑科技软件(微扑克线上)德州w... 1、黑科技软件(微扑克线上)德州wepower竟然是真的有挂!太实锤了往昔有挂(2024已更新)(哔...