当前位置: 移动技术网 > IT编程>开发语言>Java > JAVA实现简单抢红包算法(模拟真实抢红包)

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

2019年07月22日  | 移动技术网IT编程  | 我要评论

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

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实现简单抢红包算法(模拟真实抢红包),希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网