拆红包随机算法

package base;

/**

  • Created by superVV on 2018/12/13.
    */
    import java.math.BigDecimal;
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.List;
    import java.util.Random;

public class Test {
public static void main(String[] args) {
for (int i = 0; i < 10; i++) {
List 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;
}

}

猜你喜欢

转载自blog.csdn.net/fight_man8866/article/details/84984490
今日推荐