权重随机算法Java实现
2015-06-10 19:07
453 查看
权重随机算法在抽奖,资源调度等系统中应用还是比较广泛的,一个简单的按照权重来随机的实现,权重为几个随机对象(分类)的命中的比例,权重设置越高命中越容易,之和可以不等于100;
简单实现代码如下:
?
简单实现代码如下:
?
importjava.util.ArrayList; importjava.util.List; importjava.util.Random; publicclass WeightRandom { staticList<WeightCategory> categorys = newArrayList<WeightCategory>(); privatestatic Random random = newRandom(); publicstatic void initData() { WeightCategory wc1 = newWeightCategory("A",60); WeightCategory wc2 = newWeightCategory("B",20); WeightCategory wc3 = newWeightCategory("C",20); categorys.add(wc1); categorys.add(wc2); categorys.add(wc3); } publicstatic void main(String[] args) { initData(); Integer weightSum = 0; for(WeightCategory wc : categorys) { weightSum += wc.getWeight(); } if(weightSum <= 0) { System.err.println("Error: weightSum=" + weightSum.toString()); return; } Integer n = random.nextInt(weightSum); // n in [0, weightSum) Integer m = 0; for(WeightCategory wc : categorys) { if(m <= n && n < m + wc.getWeight()) { System.out.println("This Random Category is "+wc.getCategory()); break; } m += wc.getWeight(); } } } classWeightCategory { privateString category; privateInteger weight; publicWeightCategory() { super(); } publicWeightCategory(String category, Integer weight) { super(); this.setCategory(category); this.setWeight(weight); } publicInteger getWeight() { returnweight; } publicvoid setWeight(Integer weight) { this.weight = weight; } publicString getCategory() { returncategory; } publicvoid setCategory(String category) { this.category = category; } }
相关文章推荐
- java web 开发学习路线1
- java poi 技术总结
- SpringMVC中使用Interceptor拦截器
- Eclipse中jsp、js文件编辑时,卡死现象解决汇总
- gradle传递参数给Java项目的main函数
- 如何通过反编译工具与插件 查看java *.class 文件源码
- java容易混淆的知识点
- JAVA求集合中的组合
- 五、JAVA中类的探究-父子实例的内存控制
- 头像上传以及之前预览再以及剪裁——javaweb版本
- java web系列之一 web容器的理解
- 【深入JAVA】JDK静动态代理
- struts2 action 之间的跳转
- Java基础加强总结(二)——泛型
- jdb 调试java
- Myeclipse9M1 手动安装插件 读取properties文件 修改bundles.info
- java NIO 学习笔记
- java中的static详解
- Using reCaptcha with java/jsp
- eclipse在多modules项目结构下避免模块间依赖引用的场景