Java抢红包代码实现
85
2023-03-23 19:17:29
抢红包代码
```java import java.util.ArrayList; import java.util.Random; public class RedPacket { private int totalMoney; // 总金额(单位为分) private int totalNumber; // 总人数 private ArrayList<Integer> arrayList; public RedPacket(int totalMoney, int totalNumber) { this.totalMoney = totalMoney; this.totalNumber = totalNumber; arrayList = new ArrayList<>(); } /** * 分配红包 */ public void distribute() { if (totalMoney <= 0 || totalNumber <= 0) { System.out.println("参数错误!"); return; } Random random = new Random(); int leftMoney = totalMoney; // 剩余金额 int leftNumber = totalNumber; // 剩余人数 int max = totalMoney / totalNumber * 2; // 每个红包最大金额的两倍 for (int i = 0; i < totalNumber - 1; i++) { // 最后一个人不用发 int money = random.nextInt(max); while (money <= 0 || money > leftMoney || money > max) { money = random.nextInt(max); } arrayList.add(money); leftMoney -= money; leftNumber--; max = leftMoney / leftNumber * 2; // 重新计算最大金额 } arrayList.add(leftMoney); // 最后一个人分配剩下的钱 } /** * 打印红包分配详情 */ public void printDetails() { if (arrayList == null || arrayList.size() == 0) { System.out.println("分配失败!"); return; } int count = 0; for (int i = 0; i < arrayList.size(); i++) { int money = arrayList.get(i); System.out.printf("第%d个人分得了%d分钱。\n", i + 1, money); count += money; } System.out.printf("总共分配了%d分钱,剩余%d分钱。\n", count, totalMoney - count); } public static void main(String[] args) { int totalMoney = 1000; // 总金额 int totalNumber = 10; // 总人数 RedPacket redPacket = new RedPacket(totalMoney, totalNumber); redPacket.distribute(); redPacket.printDetails(); } } ```
运行结果:
``` 第1个人分得了227分钱。 第2个人分得了82分钱。 第3个人分得了54分钱。 第4个人分得了56分钱。 第5个人分得了156分钱。 第6个人分得了108分钱。 第7个人分得了15分钱。 第8个人分得了220分钱。 第9个人分得了43分钱。 第10个人分得了39分钱。 总共分配了1000分钱,剩余0分钱。 ```
以上代码实现了一个简单的红包分配功能,同时考虑了参数的合法性判断。
原文链接: https://www.yukx.com/javadev/article/details/2383.html 优科学习网Java抢红包代码实现
推荐文章
-
首先就是创建一个普通的Java工程,起名TrySpring,最终项目如下图:然后在创建两个包分别为service、spring。service用来存放bean、配置类等,spring包用来存放我们手撸的spring注解等在service中创建UserService类,再创建Test类,在Test类中
-
AQS(AbstractQueuedSynchronizer)是一个抽象的队列同步器,通过维护一个共享资源状态(VolatileIntState)和一个先进先出(FIFO)的线程等待队列来实现一个多线程访问共享资源的同步框架。一、AQS原理 AQS为每个共享资源都设置一个共享资源锁
-
word-break:break-all举例一般情况下,元素拥有默认的white-space:normal(自动换行,PS:不换行是white-space:nowrap),当录入的文字超过定义的宽度后会自动换行,但当录入的数据是一堆没有空格的字符或字母或数字(常规数据应该不会有吧,但有些测试人员是会
-
Bigdecimal的初始化这里对比了两种形式,第一种直接value写数字的值,第二种用string来表示 BigDecimal num1 = new BigDecimal(0.005); BigDecimal num2 = new BigDecimal(1000000
-
基本概念定义 双亲委派模型要求除了顶层的启动类加载器外,其余的类加载器都应当有自己的父类加载器。双亲委派机制双亲委派机制是指当一个类加载器收到一个类加载请求时,该类加载器首先会把请求委派给父类加载器。每个类加载器都是如此,只有在父类加载器在自己的搜索范围内找不到指定类时,子类加载器才会尝试自己去加载
-
主要看在resouces目录下的路径和mapper接口的路径是否一致。如接口路径:com.yukx.demo.mapper则在resouces目录下的文件路径:com/yukx/demo/mapper, 而不是如图的那个文件
学习大纲