亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java寫的偽微信紅包功能示例代碼

 更新時間:2019年08月08日 14:14:58   作者:田小江  
這篇文章主要介紹了java寫的偽微信紅包功能示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

性能優(yōu)化點:

1.使用int不使用double。(單位用分不用元)也省去了還要用math.round四舍五入,把double類型數(shù)據(jù)只留小數(shù)點后前兩位。

2.random() 方法用于返回一個隨機數(shù),隨機數(shù)范圍為 0.0 =< Math.random < 1.0。所以,當每人只能分到1分錢時,不用生成隨機數(shù)(隨機數(shù)只能生成0分,不大于最小值,會死循環(huán))。

import java.util.HashMap;
import java.util.Map;

public class WXTRedPackage {
  public static void main(String[] args) {
    WXTRedPackage wx = new WXTRedPackage();
    // 紅包錢數(shù)(以分為單位),個數(shù)
    wx.WXMoney(1000, 50);
  }

  public void WXMoney(int sum, int num) {
    // 創(chuàng)建一個hashmap,把分配出來的人和錢順序打亂
    Map<Integer, Integer> moneyMap = new HashMap();
    System.out.println("共計" + sum / 100 + "元紅包,分成" + num + "份。開始:");
    int min = 0;
    int balance = sum;
    int money = 0;
    for (int i = 0; i < num; i++) {
      if ((double) sum / num == 1) {
        moneyMap.put(i, 1);
      } else {
        // 最大可分配數(shù)目為剩下的人每人至少1分錢
        int max = balance - (num - i - 1) * 1;
        // 獲取一個0-最大可分配數(shù)的隨機數(shù)
        money = (int) (Math.random() * max);
        // 最后一個人全分配最后的余額
        if (i == num - 1) {
          moneyMap.put(i, balance);
          break;
        } else {
          // 分配的金額要超過0份,小于最大可分配數(shù),不符合要求則把人數(shù)減一重新循環(huán)一次
          if (money > min && money < max) {
            balance -= money;
            moneyMap.put(i, money);
          } else {
            i = i - 1;
          }
        }
      }
    }
    for (Integer key : moneyMap.keySet()) {
      System.out.println("第" + (key + 1) + "人獲取紅包"
          + (double) moneyMap.get(key) / 100 + "元!");
    }
  }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

最新評論