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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Spring?Boot小型項目如何使用異步任務管理器實現(xiàn)不同業(yè)務間的解耦
這篇文章主要介紹了Spring?Boot小型項目如何使用異步任務管理器實現(xiàn)不同業(yè)務間的解耦,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-08-08idea?Maven?插件?docker-maven-plugin?打包docker鏡像上傳到遠程倉庫的過程詳解
這篇文章主要介紹了idea Maven插件docker-maven-plugin打包docker鏡像上傳到遠程倉庫,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-05-05Java實現(xiàn)調(diào)用對方http接口得到返回數(shù)據(jù)
這篇文章主要介紹了Java實現(xiàn)調(diào)用對方http接口得到返回數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09