码迷,mamicode.com
首页 > 编程语言 > 详细

Java使用ArrayList实现“群主发红包”功能

时间:2020-07-14 21:42:13      阅读:87      评论:0      收藏:0      [点我收藏+]

标签:idt   好的   问题   越界   void   rgs   color   war   int   

群主发普通红包,某群有多名成员,群主给成员发普通红包,普通红包的规则:

  1. 群主的一笔金额,从群主余额中扣除,平均分成n等份,让成员领取;
  2. 成员领取红包后,保存到成员余额中。

请根据描述,完成案例中所有类的定义以及指定类之间的继承关系,并完成发红包的操作。

技术图片

 

 根据题目可以稍作分析,群主和普通群成员都隶属于用户类,那么久可以建立一个用户类,用户类的属性可以有用户名,金额或者钱包,如下:

 1 package day05_after03;
 2 
 3 /**
 4  * 定义成员类
 5  *
 6  * @author liuwenlong
 7  * @create 2020-07-14 18:08:25
 8  */
 9 @SuppressWarnings("all")
10 public class Human {
11     private String name;
12     private int age;
13     private int wallet;
14 
15     public Human() {
16     }
17 
18     public int getWallet() {
19         return wallet;
20     }
21 
22     public void setWallet(int wallet) {
23         this.wallet = wallet;
24     }
25 
26     public Human(String name, int age) {
27         this.name = name;
28         this.age = age;
29     }
30 
31     public String getName() {
32         return name;
33     }
34 
35     public void setName(String name) {
36         this.name = name;
37     }
38 
39     public int getAge() {
40         return age;
41     }
42 
43     public void setAge(int age) {
44         this.age = age;
45     }
46 
47     public String showInfo() {
48         return getName() + ", 余额:" + getWallet();
49     }
50 }

 

然后定义一个管理员类,管理员实现发红包的过程,可以通过以下方法

 1  /**
 2      * 群主发红包
 3      *
 4      * @param amount int 红包大小
 5      * @param count  int 红包个数
 6      * @return 返回拆分好的红包数组
 7      */
 8     public ArrayList<Integer> hangOut(int amount, int count) {
 9         ArrayList<Integer> RedPackage = new ArrayList<>();//创建一个数列,存放N份红包
10         if (!(this.getWallet() < amount)) {
11             int whole = amount / count;//整的钱
12             int surplus = amount % count;//余下的钱
13             for (int i = 0; i < count - 1; i++) {
14                 RedPackage.add(whole);
15             }
16             RedPackage.add((whole + surplus));//余下的加到最后一个上面
17             int getMoney = getWallet();
18             setWallet(getMoney - amount);//修改群主的钱包
19         } else {
20             System.out.println("余额不足!");
21             return null;
22         }
23         return RedPackage;
24     }

whole是要发的金额整除要发的份数,如果有余下的钱则存放到surplus中,使用循环将钱放到可变长数组里,并且将最后一个和余数相加,最后返回该可变长数组。

接下来就是群成员进行拆分红包,核心代码如下:

 1  /**
 2      * 群成员拆红包
 3      *
 4      * @param redPack 群主打包好的红包数组,随机抽取一个
 5      */
 6     public void receive(ArrayList<Integer> redPack) {
 7         int index = (int) (Math.random() * redPack.size());//从0到当前值取随机数,当前值递减
 8         int numberRedPack = redPack.get(index);//根据下标获取金额
 9         int selfAcount = getWallet();//获取自己之前的金额
10         setWallet((selfAcount + numberRedPack));//重新设置钱包
11         redPack.remove(index);//将红包数组内的这个红包删除,个数减少
12     }

使用可变长数组ArrayList的好处就是可以不用考虑数组越界的问题。

最后定义一个测试类,实例化出管理员和三个群成员,

 1 /**
 2  * 群主发红包
 3  *
 4  * @author liuwenlong
 5  * @create 2020-07-14 18:35:04
 6  */
 7 @SuppressWarnings("all")
 8 public class TestRedPack {
 9     public static void main(String[] args) {
10         ArrayList<Integer> red = new ArrayList<>();
11         Manage manage = new Manage("管理员", 20, 100);
12         Member m1 = new Member("张三", 18, 0);
13         Member m2 = new Member("李四", 17, 0);
14         Member m3 = new Member("王五", 16, 0);
15 
16         System.out.println(manage.showInfo());
17         System.out.println(m1.showInfo());
18         System.out.println(m2.showInfo());
19         System.out.println(m3.showInfo());
20 
21         System.out.println("=====================================================");
22         red = manage.hangOut(20, 3);//群主发红包
23         m1.receive(red);
24         m2.receive(red);
25         m3.receive(red);
26 
27         System.out.println(manage.showInfo());
28         System.out.println(m1.showInfo());
29         System.out.println(m2.showInfo());
30         System.out.println(m3.showInfo());
31 
32     }
33 }

最后将群主拆分好的红包返回到可变长数组red中,然后以此传给每个群成员。最终运行结果如下:

技术图片

 

Java使用ArrayList实现“群主发红包”功能

标签:idt   好的   问题   越界   void   rgs   color   war   int   

原文地址:https://www.cnblogs.com/lwl80/p/13301188.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!