码迷,mamicode.com
首页 > 编程语言 > 详细

权重随机算法

时间:2015-02-15 15:08:40      阅读:782      评论:0      收藏:0      [点我收藏+]

标签:算法   随机   权重   

权重随机算法在抽奖,资源调度等系统中应用还是比较广泛的,一个简单的按照权重来随机的实现,权重为几个随机对象(分类)的命中的比例,权重设置越高命中越容易,之和可以不等于100;

 

技术分享

简单实现代码如下:

 

import java.util.ArrayList;
import java.util.List;
import java.util.Random;

public class WeightRandom {
	static List<WeightCategory>  categorys = new ArrayList<WeightCategory>();
	private static Random random = new Random();
	
	public static void initData() {
		WeightCategory wc1 = new WeightCategory("A",60);
		WeightCategory wc2 = new WeightCategory("B",20);
		WeightCategory wc3 = new WeightCategory("C",20);
		categorys.add(wc1);
		categorys.add(wc2);
		categorys.add(wc3);
	}

	public static 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();
		  }

		  
	}

}

class WeightCategory {
	private String category;
	private Integer weight;
	

	public WeightCategory() {
		super();
	}

	public WeightCategory(String category, Integer weight) {
		super();
		this.setCategory(category);
		this.setWeight(weight);
	}


	public Integer getWeight() {
		return weight;
	}

	public void setWeight(Integer weight) {
		this.weight = weight;
	}

	public String getCategory() {
		return category;
	}

	public void setCategory(String category) {
		this.category = category;
	}
}


 

 

权重随机算法

标签:算法   随机   权重   

原文地址:http://blog.csdn.net/liuzhoulong/article/details/43835019

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!