不重复的加权随机抽样数组项
创始人
2025-01-12 12:30:42
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的列表,包含了从数组中加权随机抽样得到的项。

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...