JAVA實現 簡單搶紅包算法,模擬真實搶紅包。


   閑來無事,最近項目需求要寫出用戶登錄首頁來發現金紅包,沒有限額。我就自己稍微計算了一下如果有限額該怎么寫。覺得這樣與微信紅包差不多。等項目需求完成以后。正好來博客貼一下我自己寫的拆紅包算法。個人覺得這個算法比較模擬現實搶紅包規則。廢話少說。先貼代碼;

 

import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Random;

public class TestMain {
    public static void main(String[] args) {
        for (int i = 0; i < 10; i++) {
            List<BigDecimal> moneys = math(BigDecimal.valueOf(10), 6);
            if (moneys != null) {
                BigDecimal b = new BigDecimal(0);
                for (BigDecimal bigDecimal : moneys) {
                    System.out.print(bigDecimal + "元    ");
                    b = b.add(bigDecimal);
                }
                System.out.print("   總額:" + b+"元 ");
                System.out.println();
            }
        }
    }

    /**
     * 計算每人獲得紅包金額;最小每人0.01元
     * @param mmm 紅包總額
     * @param number 人數
     * @return
     */
    public static List<BigDecimal> math(BigDecimal mmm, int number) {
        if (mmm.doubleValue() < number * 0.01) {
            return null;
        }
        Random random = new Random();
        // 金錢,按分計算 10塊等於 1000分
        int money = mmm.multiply(BigDecimal.valueOf(100)).intValue();
        // 隨機數總額
        double count = 0;
        // 每人獲得隨機點數
        double[] arrRandom = new double[number];
        // 每人獲得錢數
        List<BigDecimal> arrMoney = new ArrayList<BigDecimal>(number);
        // 循環人數 隨機點
        for (int i = 0; i < arrRandom.length; i++) {
            int r = random.nextInt((number) * 99) + 1;
            count += r;
            arrRandom[i] = r;
        }
        // 計算每人拆紅包獲得金額
        int c = 0;
        for (int i = 0; i < arrRandom.length; i++) {
            // 每人獲得隨機數相加 計算每人占百分比
            Double x = new Double(arrRandom[i] / count);
            // 每人通過百分比獲得金額
            int m = (int) Math.floor(x * money);
            // 如果獲得 0 金額,則設置最小值 1分錢
            if (m == 0) {
                m = 1;
            }
            // 計算獲得總額
            c += m;
            // 如果不是最后一個人則正常計算
            if (i < arrRandom.length - 1) {
                arrMoney.add(new BigDecimal(m).divide(new BigDecimal(100)));
            } else {
                // 如果是最后一個人,則把剩余的錢數給最后一個人
                arrMoney.add(new BigDecimal(money - c + m).divide(new BigDecimal(100)));
            }
        }
        // 隨機打亂每人獲得金額
        Collections.shuffle(arrMoney);
        return arrMoney;
    }
}

這套代碼的思考邏輯:

      1.首先我們要根據人數來把紅包金額拆成N份,但是因為平均值問題。如果每人分得太平均會顯得可玩性不大。

      2.其次,我們該怎么分?來保證紅包可玩性較強。其實我覺得這些都不重要。畢竟紅包只看運氣。我玩微信紅包運氣不好20元3個人分我也抽到過0.01元。並發量也會很大。所以我這套代碼只是簡單的把所有人都會出一個隨機數(隨機數范圍是 人數*100),把這些人的隨機數加在一起然后來算每人隨機數的百分比。按這個百分比來瓜分紅包。

輸出結果:

       

因為最后分錢的decimal集合順序被打亂。所以不存在先抽的金額或者后抽的金額大。而且額度也不算離譜。最終還是憑借自己的運氣吧。

新人首發博客。可能有想不到的地方歡迎來討論。

您的點贊推薦是我發博客的最大動力。本人喜歡算法類程序。歡迎來討論問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM