Java实现按比抽奖功能
需求是要做几个小游戏的抽奖功能,需要根据不同的游戏有不同的抽奖规则,其中也有很多共性,可归纳为只按奖品占比抽取、奖品占比与奖品数量抽取、分段抽取,为方便起见将这些的抽奖的规则统一封装到了工具类中。抽奖的核心逻辑使用的叫做离散算法实现的。
一.概述
使用离散算法即根据奖品占比进行分段,然后再产生随机数匹配所对应的区间。
首先定义Prize奖品实体类,类中有prizeName(奖品名称)、prizeWeight(奖品比重)、prizeCount(奖品数量)属性,下面是核心的代码:
/** *按比例随机抽取一项 *@paramlist奖品列表 *@return类型值 */ publicstaticStringratioExtract(Listlist){ //非空判断 if(list==null||list.size()<1){ returnnull; } //占比之和 doublesum=0.00; //分段数组(20,30,60) double[]subArray=newdouble[list.size()+1]; //将概率分段 for(inti=0;i =subArray[i]&&rand 二、测试
以下是完整的抽奖工具类
importlombok.Data; importorg.apache.commons.lang.math.RandomUtils; importjava.util.List; importjava.util.Random; /** *@Description:抽奖工具类 *@author:xiake *@Date:2020/1/513:23 *@ModifiedDate:2020/1/513:23 *@Copyright:miaoxaike.com */ publicclassPrizeMathRandom{ /** *按比例随机抽取一项 *@paramfieldArray类型值数组 *@paramproportions与类型值对应的占比值 *@return类型值 */ publicstaticStringratioExtract(String[]fieldArray,double[]proportions){ //判断两个数组长度是否相等 if(fieldArray.length!=proportions.length){ return"两数组长度不相等,无法执行"; } //占比之和 doublesum=0.00; //分段数组(20,30,60) double[]subArray=newdouble[proportions.length+1]; //将概率分段 for(inti=0;i=subArray[i]&&rand list){ //非空判断 if(list==null||list.size()<1){ returnnull; } //占比之和 doublesum=0.00; //分段数组(20,30,60) double[]subArray=newdouble[list.size()+1]; //将概率分段 for(inti=0;i =subArray[i]&&rand 除了核心的实现方法外另外还补充了两个扩充的方法为满足游戏规则所用。下面简单做个测试
publicstaticvoidmain(String[]args){ //初始化奖品信息 ListprizeList=newArrayList<>(); prizeList.add(newPrize("一等奖",1,1)); prizeList.add(newPrize("二等奖",3,4)); prizeList.add(newPrize("三等奖",6,5)); for(inti=0;i<12;i++){ Prizeprize=ratioExtract(prizeList); if(prize!=null){ System.out.println("第"+(i+1)+"次,抽中"+prize.getPrizeName()+"剩余奖品数量="+prize.getPrizeCount()); }else{ System.out.println("第"+(i+1)+"次,奖品已抽完"); } } } 运行效果如下
实现的方法很简单,可能还有些不合理的地方,但也足以满足当前需求了。基本上都是对数组与随机数的使用就不详细讲解了,有问题欢迎在评论区留言!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。