搶紅包算法

今天分享一篇有趣的搶紅包算法,基本原理就是“二倍均值”,簡單說,也就是一個公式,在這里,令P為人數(shù),M為紅包總金額,那么每次搶到的紅包金額=隨機(jī)區(qū)間(0,P/Mx2),這樣才可以保證每次搶到隨機(jī)金額的均值是相等的。

下面是簡單的代碼:

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:剩餘金額
// 每次搶到金額:隨機(jī)區(qū)間[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("請輸入人數(shù):");
        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;//剩餘人數(shù)
        Random random = new Random();
        for (int i = 0; i < TotalPeople - 1; i++) {
            //隨機(jī)範(fàn)圍:[1,剩餘人均金額的兩倍]
            int amount = random.nextInt(restAmount / restPeople * 2 - 1) + 1;
            restAmount -= amount;
            restPeople--;
            amountList.add(amount);
        }
        amountList.add(restAmount);
        return amountList;
    }
}

下面是運行的結(jié)果:


運行結(jié)果
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容