美文网首页
抢红包算法

抢红包算法

作者: Arthur_Pluto | 来源:发表于2018-12-19 21:57 被阅读0次

今天分享一篇有趣的抢红包算法,基本原理就是“二倍均值”,简单说,也就是一个公式,在这里,令P为人数,M为红包总金额,那么每次抢到的红包金额=随机区间(0,P/Mx2),这样才可以保证每次抢到随机金额的均值是相等的。

下面是简单的代码:

package Sort_normal;

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.Scanner;

// M:剩餘紅包
// N:剩餘金額
// 每次搶到金額:隨機區間[0,M/Nx2]
public class Red_Package {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        System.out.println("请输入红包金额:");
        Integer TotalAmount = in.nextInt();
        System.out.println("请输入人数:");
        Integer TotalPeople = in.nextInt();
        List<Integer> amountList = RedPackage(TotalAmount, TotalPeople);
//        String[] NameList = new String[]{"小黄", "张三", "李四", "王五", "鹤叔", "丽丽", "小明", "阿杰", "媚姐", "王姨"};
        for (Integer amount : amountList) {
            System.out.println("搶到金額:" + new BigDecimal(amount).divide(new BigDecimal(100)) + "元");
        }
    }

    public static List<Integer> RedPackage(Integer TotalAmount, Integer TotalPeople) {
        List<Integer> amountList = new ArrayList<Integer>();
        Integer restAmount = TotalAmount;//剩餘金額
        Integer restPeople = TotalPeople;//剩餘人數
        Random random = new Random();
        for (int i = 0; i < TotalPeople - 1; i++) {
            //隨機範圍:[1,剩餘人均金額的兩倍]
            int amount = random.nextInt(restAmount / restPeople * 2 - 1) + 1;
            restAmount -= amount;
            restPeople--;
            amountList.add(amount);
        }
        amountList.add(restAmount);
        return amountList;
    }
}

下面是运行的结果:


运行结果

相关文章

  • 尝试写一个抢红包算法

    抢红包算法看似简单,实际还是不简单啊!

  • 抢红包算法

    抢红包大家都知道,但发出一个固定金额的红包,由若干个人来抢,需要满足哪些规则? 所有人抢到金额之和等于红包金额,不...

  • 抢红包算法

    今天分享一篇有趣的抢红包算法,基本原理就是“二倍均值”,简单说,也就是一个公式,在这里,令P为人数,M为红包总金额...

  • Golang洗牌算法,抢红包算法

    本文为转载,原文:Golang洗牌算法,抢红包算法 1. 洗牌算法 洗牌算法,即将原来的顺序打乱,组成新的随机排序...

  • 抢红包算法@随机算法

    生成随机数 注:randomElement() 如果 range 是空,返回 nil 数组随机 洗牌算法 Swif...

  • 实现抢红包算法

    发出一个固定金额的红包,由若干人来抢,需要满足哪些规则? 1.所有人抢到金额之和等于红包金额,不能超过,也不能少于...

  • 红包

    抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包抢红包...

  • PHP-抢红包算法

    看到很多人写,自己也写了个。大概的主要思路:比如一个红包20元5个人抢,最小单位为1元。第一个人抢的范围必须是,1...

  • 抢红包基本算法尝试

    在生活中,抢红包无处不在,既为我们带来金钱的流通,也为我们带来惊喜;但其背后的算法严密而复杂,既要保证公平,又要充...

  • js模拟微信抢红包算法的讨论

    春节在家无聊,抢红包的时候想起来,不如自己写一个微信抢红包算法来练练手。本以为是非常简单的一个事情,但真正写下来也...

网友评论

      本文标题:抢红包算法

      本文链接:https://www.haomeiwen.com/subject/dqvskqtx.html