LeetCode 528. 按权重随机选择

2023-10-31 13:32

本文主要是介绍LeetCode 528. 按权重随机选择,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:

力扣icon-default.png?t=M3K6https://leetcode-cn.com/problems/random-pick-with-weight/

【分析】如果直接用水塘取样的话会超时,因为查询次数为10^4,每次查询时需要枚举10^4长度的数组,而Random.nextInt()中的参数可以达到10^9。

class Solution {Random random = new Random();int[] w;int[] p;int n;public Solution(int[] w) {this.w = w;this.n = w.length;p = new int[n];p[0] = w[0];for(var i = 1; i < n; i++) p[i] = p[i - 1] + w[i];}public int pickIndex() {int ans = 0;for(var i = 0; i < n; i++){if(random.nextInt(p[i]) < w[i]) ans = i;}return ans;}
}

【方法二 前缀和+枚举】把概率值求前缀和,然后生成一个概率综合范围内的随机数r,查找到第一个>r的前坠值,也就把概率用区间长度来表示了,看随机数落在哪个区间内。

class Solution {int[] w;int n;public Solution(int[] w) {this.w = w;n = w.length;for(var i = 1; i < n; ++i){w[i] += w[i - 1];}}public int pickIndex() {double random = Math.random() * w[n - 1];for(var i = 0; i < n; ++i){if(w[i] > random) return i;}return n - 1;}
}

【优化 前缀和+二分查找】我们发现前缀和事一个排好序的数组,我们要查找大于目标r的最小值,所以这个查询过程可以用二分来实现。

class Solution {int[] w;int n;Random random = new Random();public Solution(int[] w) {this.w = w;n = w.length;for(var i = 1; i < n; ++i){w[i] += w[i - 1];}}public int BinarySearch(int left, int right, double target){int mid;while(left <= right){mid = (left + right) / 2;if(w[mid] <= target) left = mid + 1;else right = mid - 1;}return left;}public int pickIndex() {double r = random.nextInt(w[n - 1]);return BinarySearch(0, n - 1, r);}
}

 

 

 

 

这篇关于LeetCode 528. 按权重随机选择的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/315707

相关文章

exfat和ntfs哪个好? U盘格式化选择NTFS与exFAT的详细区别对比

《exfat和ntfs哪个好?U盘格式化选择NTFS与exFAT的详细区别对比》exFAT和NTFS是两种常见的文件系统,它们各自具有独特的优势和适用场景,以下是关于exFAT和NTFS的详细对比... 无论你是刚入手了内置 SSD 还是便携式移动硬盘或 U 盘,都需要先将它格式化成电脑或设备能够识别的「文

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

基于Python实现多语言朗读与单词选择测验

《基于Python实现多语言朗读与单词选择测验》在数字化教育日益普及的今天,开发一款能够支持多语言朗读和单词选择测验的程序,对于语言学习者来说无疑是一个巨大的福音,下面我们就来用Python实现一个这... 目录一、项目概述二、环境准备三、实现朗读功能四、实现单词选择测验五、创建图形用户界面六、运行程序七、

前端知识点之Javascript选择输入框confirm用法

《前端知识点之Javascript选择输入框confirm用法》:本文主要介绍JavaScript中的confirm方法的基本用法、功能特点、注意事项及常见用途,文中通过代码介绍的非常详细,对大家... 目录1. 基本用法2. 功能特点①阻塞行为:confirm 对话框会阻塞脚本的执行,直到用户作出选择。②

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

使用C#如何创建人名或其他物体随机分组

《使用C#如何创建人名或其他物体随机分组》文章描述了一个随机分配人员到多个团队的代码示例,包括将人员列表随机化并根据组数分配到不同组,最后按组号排序显示结果... 目录C#创建人名或其他物体随机分组此示例使用以下代码将人员分配到组代码首先将lstPeople ListBox总结C#创建人名或其他物体随机分组

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c