java 权重_java实现权重的简单算法

有抽奖自然就有三六九等,自然又是金字塔模式。下面贴出我的demo代码,然后一一解答。文章尾部有我的参考链接,大部分代码来源于他,我只是稍微优化。

import java.util.ArrayList;

import java.util.List;

/**

* Created by liyang on 2017/7/13.

*/

public class PrizeTest {

/**

* 根据Math.random()产生一个double型的随机数,判断每个供应商出现的概率

* @param prizes

* @return random:奖品列表prizes中的序列(prizes中的第random个就是抽中的奖品)

*/

public static int getPrizeIndex(List prizes) {

int random = -1;

while(random < 0 ) {

try {

//计算总权重

double sumWeight = 0;

for (Prize p : prizes) {

sumWeight += p.getPrize_weight();

}

//产生随机数

double randomNumber;

randomNumber = Math.random();

//根据随机数在所有奖品分布的区域并确定哪个供应商

double d1 = 0;

double d2 =

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值