JAVA实现简单抢红包算法(模拟真实抢红包)

 更新时间:2016年12月14日 10:52:30   作者:天雨沧澜  
这篇文章主要介绍了JAVA实现简单抢红包算法(模拟真实抢红包)的实例代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下

闲来无事,最近项目需求要写出用户登录首页来发现金红包,没有限额。我就自己稍微计算了一下如果有限额该怎么写。觉得这样与微信红包差不多。等项目需求完成以后。正好来博客贴一下我自己写的拆红包算法。个人觉得这个算法比较模拟现实抢红包规则。废话少说。先贴代码;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;
public class TestMain {
  public static void main(String[] args) {
    for (int i = 0; i < 10; i++) {
      List<BigDecimal> moneys = math(BigDecimal.valueOf(10), 6);
      if (moneys != null) {
        BigDecimal b = new BigDecimal(0);
        for (BigDecimal bigDecimal : moneys) {
          System.out.print(bigDecimal + "元  ");
          b = b.add(bigDecimal);
        }
        System.out.print("  总额:" + b+"元 ");
        System.out.println();
      }
    }
  }
  /**
   * 计算每人获得红包金额;最小每人0.01元
   * @param mmm 红包总额
   * @param number 人数
   * @return
   */
  public static List<BigDecimal> math(BigDecimal mmm, int number) {
    if (mmm.doubleValue() < number * 0.01) {
      return null;
    }
    Random random = new Random();
    // 金钱,按分计算 10块等于 1000分
    int money = mmm.multiply(BigDecimal.valueOf(100)).intValue();
    // 随机数总额
    double count = 0;
    // 每人获得随机点数
    double[] arrRandom = new double[number];
    // 每人获得钱数
    List<BigDecimal> arrMoney = new ArrayList<BigDecimal>(number);
    // 循环人数 随机点
    for (int i = 0; i < arrRandom.length; i++) {
      int r = random.nextInt((number) * 99) + 1;
      count += r;
      arrRandom[i] = r;
    }
    // 计算每人拆红包获得金额
    int c = 0;
    for (int i = 0; i < arrRandom.length; i++) {
      // 每人获得随机数相加 计算每人占百分比
      Double x = new Double(arrRandom[i] / count);
      // 每人通过百分比获得金额
      int m = (int) Math.floor(x * money);
      // 如果获得 0 金额,则设置最小值 1分钱
      if (m == 0) {
        m = 1;
      }
      // 计算获得总额
      c += m;
      // 如果不是最后一个人则正常计算
      if (i < arrRandom.length - 1) {
        arrMoney.add(new BigDecimal(m).divide(new BigDecimal(100)));
      } else {
        // 如果是最后一个人,则把剩余的钱数给最后一个人
        arrMoney.add(new BigDecimal(money - c + m).divide(new BigDecimal(100)));
      }
    }
    // 随机打乱每人获得金额
    Collections.shuffle(arrMoney);
    return arrMoney;
  }
}

这套代码的思考逻辑:

      1.首先我们要根据人数来把红包金额拆成N份,但是因为平均值问题。如果每人分得太平均会显得可玩性不大。

      2.其次,我们该怎么分?来保证红包可玩性较强。其实我觉得这些都不重要。毕竟红包只看运气。我玩微信红包运气不好20元3个人分我也抽到过0.01元。并发量也会很大。所以我这套代码只是简单的把所有人都会出一个随机数(随机数范围是 人数*100),把这些人的随机数加在一起然后来算每人随机数的百分比。按这个百分比来瓜分红包。

以上所述是小编给大家介绍的JAVA实现简单抢红包算法(模拟真实抢红包),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Spring和SpringBoot比较及区别解惑

    Spring和SpringBoot比较及区别解惑

    这篇文章主要介绍了Spring和SpringBoot比较解惑区别,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • Java实现多叉树和二叉树之间的互转

    Java实现多叉树和二叉树之间的互转

    本文主要介绍了Java实现多叉树和二叉树之间的互转,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • SpringBoot集成P6Spy实现SQL日志的记录详解

    SpringBoot集成P6Spy实现SQL日志的记录详解

    P6Spy是一个框架,它可以无缝地拦截和记录数据库活动,而无需更改现有应用程序的代码。一般我们使用的比较多的是使用p6spy打印我们最后执行的sql语句
    2022-11-11
  • Spring mvc结果跳转方法详解

    Spring mvc结果跳转方法详解

    这篇文章主要介绍了Spring mvc结果跳转方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Java 滑动窗口最大值的实现

    Java 滑动窗口最大值的实现

    这篇文章主要介绍了Java 滑动窗口最大值,给定一个数组 nums,有一个大小为 k 的滑动窗口从数组的最左侧移动到数组的最右侧。感兴趣的可以了解一下
    2021-05-05
  • Java序列化中子类、父类构造函数问题实例分析

    Java序列化中子类、父类构造函数问题实例分析

    这篇文章主要介绍了Java序列化中子类、父类构造函数问题,结合实例形式分析了java父类与子类构造函数中序列化接口调用相关操作技巧与使用注意事项,需要的朋友可以参考下
    2019-09-09
  • Java用户交互scanner及运算结构代码详解

    Java用户交互scanner及运算结构代码详解

    这篇文章主要介绍了Java用户交互scanner及运算结构代码详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12
  • 解决idea update project 更新选项消失的问题

    解决idea update project 更新选项消失的问题

    这篇文章主要介绍了解决idea update project 更新选项消失的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 理解java设计模式之建造者模式

    理解java设计模式之建造者模式

    这篇文章主要帮助大家理解java设计模式之建造者模式,对建造者模式,即生成器模式进行实例讲解,感兴趣的朋友可以参考一下
    2016-02-02
  • 创建Maven项目和Spring IOC实例过程解析

    创建Maven项目和Spring IOC实例过程解析

    这篇文章主要介绍了创建Maven项目和Spring IOC实例过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12

最新评论