package com.example.leetcode.bytes;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
public class RedEnvelope {
public static List<Integer> divideRedPackage(Integer totalAmount, Integer totalPeopleNum) {
List<Integer> amountList = new ArrayList<Integer>();
Integer restAmount = totalAmount;
Integer restPeopleNum = totalPeopleNum;
Random random = new Random();
for (int i = 0; i < totalPeopleNum - 1; i++) {
//随机范围:[1,剩余人均金额的2倍-1] 分
int amount = random.nextInt(restAmount / restPeopleNum * 2 - 1) + 1;
restAmount = restAmount - amount;
restPeopleNum--;
amountList.add(amount);
}
amountList.add(restAmount);
return amountList;
}
public static void main(String[] args) {
List<Integer> amountList = divideRedPackage(10000, 10);
int total = 0;
for (Integer amount : amountList) {
total += amount;
System.out.println(" 金额:" + amount);
}
System.out.println("Total number:" + total);
}
}
红包随机算法
最新推荐文章于 2024-08-18 18:02:49 发布
本文介绍了一个Java程序,通过随机算法将总金额均匀地分配给指定人数的人群,模拟了实际场景中红包的拆分过程。代码演示了如何创建一个RedEnvelope类,用于计算每个人获得的红包金额,并在main方法中进行测试。
摘要由CSDN通过智能技术生成