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实现简单抢红包算法(模拟真实抢红包),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • 基于Java实现的图的广度优先遍历算法

    本文以实例形式讲述了基于Java的图的广度优先遍历算法实现方法,具体方法如下: 用邻接矩阵存储图方法: 1.确定图的顶点个数和边的个数 2.输入顶点信息存储在一维数组vertex中 3.初始化邻接矩阵: 4.依次输入每条边存储在邻接矩阵arc中 输入边依附的两个顶点的序号i,j: 将邻接矩阵的第i行第j列的元素值置为1: 将邻接矩阵的第j行第i列的元素值置为1: 广度优先遍历实现: 1.初始化队列Q 2.访问顶点v:visited[v]=1;顶点v入队Q; 3.while(队列Q非空) v=队列

  • java实现哈弗曼编码与反编码实例分享(哈弗曼算法)

    复制代码 代码如下: //哈弗曼编码的实现类public class HffmanCoding {    private int charsAndWeight[][];// [][0]是 字符,[][1]存放的是字符的权值(次数)    private int hfmcoding[][];// 存放哈弗曼树    private int i = 0;// 循环变量    private String hcs[];    public HffmanCoding(int[][] chars) {  

  • java字符串相似度算法

    本文实例讲述了java字符串相似度算法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: public class Levenshtein {     private int compare(String str, String target) {         int d[][]; // 矩阵         int n = str.length();         int m = target.length();         int i; // 遍历str的      

  • java实现MD5加密算法的实例代码

    复制代码 代码如下: package other; import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;/* * MD5 算法*/public class MD5 { // 全局数组    private final static String[] strDigits = { "0", "1", "2", "3", &

  • java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述

    算法是在有限步骤内求解某一问题所使用的一组定义明确的规则.通俗点说,就是计算机解题的过程.在这个过程中,无论是形成解题思路还是编写程序,都是在实施某种算法.前者是推理实现的算法,后者是操作实现的算法. 一个算法应该具有以下五个重要的特征: 1.有穷性: 一个算法必须保证执行有限步之后结束: 2.确切性: 算法的每一步骤必须有确切的定义: 3.输入:一个算法有0个或多个输入,以刻画运算对象的初始情况: 4.输出:一个算法有一个或多个输出,以反映对输入数据加工后的结果.没有输出的算法是毫无意义的:

  • java实现的海盗算法优化版

    本文实例讲述了java实现的海盗算法.分享给大家供大家参考,具体如下: 前面介绍了<C#实现的海盗分金算法>,这里再给出一个Java优化版的算法: package unit4; public class Pirate{ private String name; private int[] schemes; private int index; public Pirate(int t,int i) { name="unknow"; index=i; schemes=makeS

  • 使用java自带des加密算法实现文件加密和字符串加密

    复制代码 代码如下: import java.io.ByteArrayInputStream;import java.io.ByteArrayOutputStream;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.InputStream;import java.io.OutputStream;import java.security.SecureR

  • 史上最全的java随机数生成算法分享

    复制代码 代码如下: String password = RandomUtil.generateString(10); 源码如下: 复制代码 代码如下: package com.javaniu.core.util;import java.util.Random;public class RandomUtil { public static final String ALLCHAR = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRS

  • JAVA简单分组的算法实现

    复制代码 代码如下: import java.util.ArrayList; import java.util.Collections; import java.util.List; /**  * Created with IntelliJ IDEA.  * User: dell  * Date: 13-3-5  * Time: 下午8:38  * To change this template use File | Settings | File Templates.  */ public c

  • 图解程序员必须掌握的Java常用8大排序算法

    这篇文章主要介绍了Java如何实现八个常用的排序算法:插入排序.冒泡排序.选择排序.希尔排序 .快速排序.归并排序.堆排序和LST基数排序,分享给大家一起学习. 分类 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序. 先来看看8种排序之间的关系: 1.直接插入排序 (1)基本思想

随机推荐