Java实现抽奖算法的示例代码
来源:脚本之家    时间:2022-04-18 11:53:00
目录
一、题目描述二、解题思路三、代码详解四、优化抽奖算法解题思路代码详解

一、题目描述

题目: 小虚竹为了给粉丝送福利,决定在参与学习打卡活动的粉丝中抽一位幸运粉丝,送份小礼物。为了公平,要保证抽奖过程是随机的。

二、解题思路

1、把参与的人员加到集合中

2、使用Random对象获取随机数

3、把随机数当下标,获取集合中的幸运用户

三、代码详解

public class Basics28 {
    public static void main(String[] args) {
        List luckUserNames = getLuckUserNames();
        Random random = new Random();
        int luckNum = random.nextInt(6);
        System.out.println("幸运的未来大佬是:"+luckUserNames.get(luckNum));
    }

    private static List getLuckUserNames(){
        List luckUserNames = new ArrayList();

        luckUserNames.add("李慢慢_");
        luckUserNames.add("TryAgain-");
        luckUserNames.add("team_dog");
        luckUserNames.add("Jasonakeke");
        luckUserNames.add("学好c语言的小王同学");
        luckUserNames.add("Ara~追着风跑");
        return luckUserNames;
    }
}

四、优化抽奖算法

解题思路

随机次数太少,需要优化

需要列出所有人随机命中的次数,显示出来,比较公开公平

代码详解

public class LuckDraw {
    public static void main(String[] args) {
        List luckUserNames = getLuckUserNames();
        Random random = new Random();
        //key:luckNum ,value:count 
        Map luckNumMap = new HashMap();
        for (int i = 0; i < 100; i++) {
            int luckNum = random.nextInt(4);
            Integer count = luckNumMap.get(luckNum);
            if(count==null){
                count = 0;
            }
            ++count;
            luckNumMap.put(luckNum,count);
        }
        Integer maxLuckNum = 0;
        Integer maxCount =0;
        for(Integer luckNum:luckNumMap.keySet()){
            if(maxCount getLuckUserNames(){
        List luckUserNames = new ArrayList();
        luckUserNames.add("学好c语言的小王同学");
        luckUserNames.add("Ara~追着风跑");
        luckUserNames.add("李慢慢_");
        luckUserNames.add("Jasonakeke");
        return luckUserNames;
    }
}

到此这篇关于Java实现抽奖算法的示例代码的文章就介绍到这了,更多相关Java抽奖算法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

关键词: 希望大家 显示出来 相关文章 幸运用户

X 关闭

X 关闭