溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用Java基于ArrayList實(shí)現(xiàn)一個(gè)群主發(fā)紅包功能

發(fā)布時(shí)間:2020-10-30 15:07:11 來(lái)源:億速云 閱讀:193 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

使用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é)果如下:

使用Java基于ArrayList實(shí)現(xiàn)一個(gè)群主發(fā)紅包功能

關(guān)于使用Java基于ArrayList實(shí)現(xiàn)一個(gè)群主發(fā)紅包功能問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI