轮盘赌算法
来源:互联网 发布:淘宝下架宝贝找不到 编辑:程序博客网 时间:2024/05/18 02:29
原文地址:http://www.cnblogs.com/littlebugfish/p/3982593.html
首先,这个算法可以如下表述:
如果已知A类对象生成概率为P(A),B类对象生成概率为P(B),C类对象···,K类对象,他们的概率总和为1,问如何在A~K中随机生成一个对象
算法理解如下:
即我们需要先对0~1区段按照概率大小划分长度,设随机生成一个0~1之间的数,这种随机数生成结果是在0~1均匀分布的,然后看其究竟落在哪个概率区段即为生成哪种对象
算法代码:
package test;import org.junit.Test;public class Roulette { @Test public void test() { double[] P={0.2,0.3,0.5};//假设的概率分布 int appearnum=0; for(int i=0;i<100;i++){ int result=roulette(P); if(result==2)//统计第2类对象生成的数目,可以看出大致为50%的生成概率 appearnum++; } System.out.println(appearnum); } /** * 轮盘赌函数 * @param P 各类对象概率分布 * @return 生成的对象类 */ private int roulette(double[] P){ double rand=Math.random(); double pointer=0;//pointer指示每个区段的右边界,从左往右扫描判断 for(int i=0;i<P.length;i++){ pointer+=P[i]; if(rand<=pointer) return i; } return -1; }}
阅读全文
0 0
- 轮盘赌算法
- 轮盘赌算法
- 轮盘赌算法-Roulette
- 轮盘赌算法
- 轮盘赌算法
- 轮盘赌算法
- 轮盘赌算法原理(ACO算法概率选择方法)
- 轮盘赌算法详细批注《游戏编程中人工智能》
- 用Python实现3种轮盘赌选择算法
- 基于树状数组的高效轮盘赌算法
- 蚁群中的轮盘算法
- 轮盘赌选择
- 俄罗斯轮盘赌
- 爱情轮盘赌
- 俄罗斯轮盘赌
- 轮盘赌选择解决思路
- C++ 轮盘赌 采用累加的思想
- 轮盘赌选择,原理及C++实现
- LaTeX使用经验
- [概率与期望 && DP] BZOJ3640 .JC的小苹果
- bootstrap实现自定义按钮导出Excel表格
- YUV转RGB
- Communications link failure的解决办法
- 轮盘赌算法
- js中for in循环对象时的取值处理
- 连续数值属性的CART decision tree
- spring+websocket整合(springMVC+spring+MyBatis即SSM框架和websocket技术的整合)
- Spring Boot整合Quartz实现定时任务表配置
- centos增加yum源方法
- Leetcode之Missing Number 问题
- 数据结构--线性链式表倒数第K项
- dubbo 配置文件详解