java寫的偽微信紅包功能示例代碼
性能優(yōu)化點:
1.使用int不使用double。(單位用分不用元)也省去了還要用math.round四舍五入,把double類型數(shù)據(jù)只留小數(shù)點后前兩位。
2.random() 方法用于返回一個隨機數(shù),隨機數(shù)范圍為 0.0 =< Math.random < 1.0。所以,當(dāng)每人只能分到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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的代碼示例
pf4j是一個插件框架,用于實現(xiàn)插件的動態(tài)加載,支持的插件格式(zip、jar),本文給大家介紹了SpringBoot集成pf4j實現(xiàn)插件開發(fā)功能的示例,文中通過代碼示例給大家講解的非常詳細,需要的朋友可以參考下2024-07-07
spring boot配置讀寫分離的完整實現(xiàn)步驟
數(shù)據(jù)庫配置主從之后,如何在代碼層面實現(xiàn)讀寫分離?所以下面這篇文章主要給大家介紹了關(guān)于spring boot配置讀寫分離的完整步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2018-09-09
IntelliJ IDEA安裝scala插件并創(chuàng)建scala工程的步驟詳細教程
這篇文章主要介紹了IntelliJ IDEA安裝scala插件并創(chuàng)建scala工程的步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
Spring中的@PropertySource注解源碼詳細解析
這篇文章主要介紹了Spring中的@PropertySource注解源碼詳細解析,@PropertySource注解,標注在配置類@Configuration上面,下面主要分析一下@PropertySource注解的處理過程,也就是怎么把配置信息從.properies文件放到environment中的,需要的朋友可以參考下2024-01-01
kafka 重新分配partition和調(diào)整replica的數(shù)量實現(xiàn)
當(dāng)需要提升Kafka集群的性能和負載均衡時,可通過kafka-reassign-partitions.sh命令手動重新分配Partition,增加節(jié)點后,可以將Topic的Partition的Leader節(jié)點均勻分布,以提高寫入和消費速度,感興趣的可以了解一下2022-03-03

