您好,登錄后才能下訂單哦!
性能優(yōu)化點(diǎn):
1.使用int不使用double。(單位用分不用元)也省去了還要用math.round四舍五入,把double類型數(shù)據(jù)只留小數(shù)點(diǎn)后前兩位。
2.random() 方法用于返回一個(gè)隨機(jī)數(shù),隨機(jī)數(shù)范圍為 0.0 =< Math.random < 1.0。所以,當(dāng)每人只能分到1分錢時(shí),不用生成隨機(jī)數(shù)(隨機(jī)數(shù)只能生成0分,不大于最小值,會(huì)死循環(huán))。
import java.util.HashMap; import java.util.Map; public class WXTRedPackage { public static void main(String[] args) { WXTRedPackage wx = new WXTRedPackage(); // 紅包錢數(shù)(以分為單位),個(gè)數(shù) wx.WXMoney(1000, 50); } public void WXMoney(int sum, int num) { // 創(chuàng)建一個(gè)hashmap,把分配出來的人和錢順序打亂 Map<Integer, Integer> moneyMap = new HashMap(); System.out.println("共計(jì)" + 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; // 獲取一個(gè)0-最大可分配數(shù)的隨機(jī)數(shù) money = (int) (Math.random() * max); // 最后一個(gè)人全分配最后的余額 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 + "元!"); } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(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)容。