您好,登錄后才能下訂單哦!
使用Java基于ArrayList實(shí)現(xiàn)一個(gè)群主發(fā)紅包功能?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
建立一個(gè)用戶類,用戶類的屬性可以有用戶名,金額或者錢包,如下:
package day05_after03; /** * 定義成員類 * * @author liuwenlong * @create 2020-07-14 18:08:25 */ @SuppressWarnings("all") public class Human { private String name; private int age; private int wallet; public Human() { } public int getWallet() { return wallet; } public void setWallet(int wallet) { this.wallet = wallet; } public Human(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String showInfo() { return getName() + ", 余額:" + getWallet(); } }
然后定義一個(gè)管理員類,管理員實(shí)現(xiàn)發(fā)紅包的過(guò)程,可以通過(guò)以下方法
/** * 群主發(fā)紅包 * * @param amount int 紅包大小 * @param count int 紅包個(gè)數(shù) * @return 返回拆分好的紅包數(shù)組 */ public ArrayList<Integer> hangOut(int amount, int count) { ArrayList<Integer> RedPackage = new ArrayList<>();//創(chuàng)建一個(gè)數(shù)列,存放N份紅包 if (!(this.getWallet() < amount)) { int whole = amount / count;//整的錢 int surplus = amount % count;//余下的錢 for (int i = 0; i < count - 1; i++) { RedPackage.add(whole); } RedPackage.add((whole + surplus));//余下的加到最后一個(gè)上面 int getMoney = getWallet(); setWallet(getMoney - amount);//修改群主的錢包 } else { System.out.println("余額不足!"); return null; } return RedPackage; }
whole是要發(fā)的金額整除要發(fā)的份數(shù),如果有余下的錢則存放到surplus中,使用循環(huán)將錢放到可變長(zhǎng)數(shù)組里,并且將最后一個(gè)和余數(shù)相加,最后返回該可變長(zhǎng)數(shù)組。
接下來(lái)就是群成員進(jìn)行拆分紅包,核心代碼如下:
/** * 群成員拆紅包 * * @param redPack 群主打包好的紅包數(shù)組,隨機(jī)抽取一個(gè) */ public void receive(ArrayList<Integer> redPack) { int index = (int) (Math.random() * redPack.size());//從0到當(dāng)前值取隨機(jī)數(shù),當(dāng)前值遞減 int numberRedPack = redPack.get(index);//根據(jù)下標(biāo)獲取金額 int selfAcount = getWallet();//獲取自己之前的金額 setWallet((selfAcount + numberRedPack));//重新設(shè)置錢包 redPack.remove(index);//將紅包數(shù)組內(nèi)的這個(gè)紅包刪除,個(gè)數(shù)減少 }
使用可變長(zhǎng)數(shù)組ArrayList的好處就是可以不用考慮數(shù)組越界的問(wèn)題。
最后定義一個(gè)測(cè)試類,實(shí)例化出管理員和三個(gè)群成員,
/** * 群主發(fā)紅包 * * @author liuwenlong * @create 2020-07-14 18:35:04 */ @SuppressWarnings("all") public class TestRedPack { public static void main(String[] args) { ArrayList<Integer> red = new ArrayList<>(); Manage manage = new Manage("管理員", 20, 100); Member m1 = new Member("張三", 18, 0); Member m2 = new Member("李四", 17, 0); Member m3 = new Member("王五", 16, 0); System.out.println(manage.showInfo()); System.out.println(m1.showInfo()); System.out.println(m2.showInfo()); System.out.println(m3.showInfo()); System.out.println("====================================================="); red = manage.hangOut(20, 3);//群主發(fā)紅包 m1.receive(red); m2.receive(red); m3.receive(red); System.out.println(manage.showInfo()); System.out.println(m1.showInfo()); System.out.println(m2.showInfo()); System.out.println(m3.showInfo()); } }
最后將群主拆分好的紅包返回到可變長(zhǎng)數(shù)組red中,然后以此傳給每個(gè)群成員。最終運(yùn)行結(jié)果如下:
關(guān)于使用Java基于ArrayList實(shí)現(xiàn)一個(gè)群主發(fā)紅包功能問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。