栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java实现按比抽奖功能

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java实现按比抽奖功能

需求是要做几个小游戏的抽奖功能,需要根据不同的游戏有不同的抽奖规则,其中也有很多共性,可归纳为只按奖品占比抽取、奖品占比与奖品数量抽取、分段抽取,为方便起见将这些的抽奖的规则统一封装到了工具类中。抽奖的核心逻辑使用的叫做离散算法实现的。

一.概述

使用离散算法即根据奖品占比进行分段,然后再产生随机数匹配所对应的区间。
首先定义Prize奖品实体类,类中有prizeName(奖品名称)、prizeWeight(奖品比重)、prizeCount(奖品数量)属性,下面是核心的代码:

 
  public static String ratioExtract(List list) {
    //非空判断
    if (list==null || list.size()<1) {
      return null;
    }
    //占比之和
    double sum=0.00;
    //分段数组(20,30,60)
    double[] subArray=new double[list.size()+1];
    //将概率分段
    for (int i = 0; i < list.size(); i++) {
      subArray[i]=sum;
      //这里除要考虑奖品所占比重外还要将奖品数量计算分段其中
      sum+=list.get(i).getPrizeWeight()*list.get(i).getPrizeCount();
    }
    //加上取最大的值
    subArray[subArray.length-1]=sum;

    
    Random random=new Random();
    double rand = random.nextDouble()*sum;

    //返回字符
    String field=null;
    for (int i = 0; i < subArray.length; i++) {
      if (i==subArray.length-1) {
 return field;
      }
      if (rand>=subArray[i] && rand

二、测试

以下是完整的抽奖工具类

import lombok.Data;
import org.apache.commons.lang.math.RandomUtils;

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


public class PrizeMathRandom {

  
  public static String ratioExtract(String[] fieldArray,double[] proportions) {
    //判断两个数组长度是否相等
    if(fieldArray.length!=proportions.length) {
      return "两数组长度不相等,无法执行";
    }

    //占比之和
    double sum=0.00;
    //分段数组(20,30,60)
    double[] subArray=new double[proportions.length+1];
    //将概率分段
    for (int i = 0; i < proportions.length; i++) {
      subArray[i]=sum;
      sum+=proportions[i];
    }
    //加上取最大的值
    subArray[subArray.length-1]=sum;
    Random random=new Random();
    
    double rand = random.nextDouble()*sum;
    //返回字符
    String field=null;
    for (int i = 0; i < subArray.length; i++) {
      if (rand>=subArray[i] && rand list) {
    //非空判断
    if (list==null || list.size()<1) {
      return null;
    }
    //占比之和
    double sum=0.00;
    //分段数组(20,30,60)
    double[] subArray=new double[list.size()+1];
    //将概率分段
    for (int i = 0; i < list.size(); i++) {
      subArray[i]=sum;
      sum+=list.get(i).getPrizeWeight()*list.get(i).getPrizeCount();
    }
    //加上取最大的值
    subArray[subArray.length-1]=sum;

    
    Random random=new Random();
    double rand = random.nextDouble()*sum;

    //返回字符
    String field=null;
    for (int i = 0; i < subArray.length; i++) {
      if (i==subArray.length-1) {
 return field;
      }
      if (rand>=subArray[i] && rand

除了核心的实现方法外另外还补充了两个扩充的方法为满足游戏规则所用。下面简单做个测试

public static void main(String[] args) {
    //初始化奖品信息
    List prizeList=new ArrayList<>();
    prizeList.add(new Prize("一等奖",1,1));
    prizeList.add(new Prize("二等奖",3,4));
    prizeList.add(new Prize("三等奖",6,5));

    for (int i = 0; i < 12; i++) {
      Prize prize = ratioExtract(prizeList);
      if (prize!=null){
 System.out.println("第"+(i+1)+"次,抽中 "+prize.getPrizeName()+" 剩余奖品数量="+prize.getPrizeCount());
      }else {
 System.out.println("第"+(i+1)+"次,奖品已抽完");
      }

    }
  }

运行效果如下

实现的方法很简单,可能还有些不合理的地方,但也足以满足当前需求了。基本上都是对数组与随机数的使用就不详细讲解了,有问题欢迎在评论区留言!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/135548.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号