java题目之抽奖以及优化方式

复制代码
public class Main9 {
    public static void main(String[] args) {

        int[]arr={ 2,588,888,1000,10000};
        int [] newArr=new int[arr.length];

        //3.抽奖
        Random r=new Random();
        //因为有5个奖项,所以这里循环五次
        for (int i = 0; i <5 ; ) {
           //获取随机索引
            int randomIndex=r.nextInt(arr.length);
            //获取奖项
            int prize=arr[randomIndex];
            //判断当前的奖项是否存在,如果存在就重新抽取,如果不存在,就表示有效奖项
           boolean flag= contains(newArr,prize);
            if (!flag) {
                newArr[i]=prize;
                i++;
            }
        }

        for (int i = 0; i <newArr.length ; i++) {
            System.out.println(newArr[i]) ;

        }
    }

    //判断prize在数组当中是否存在
    //存在的话:true
    //不存在的话:false


    public static  boolean contains(int[] arr, int prize) {
     for(int i=0; i<arr.length; i++) {
         if(arr[i]==prize) {
             return true;
         }
    }
     return false;
    }
}
复制代码
优化以后的代码:
public class Main10 {
    public static void main(String[] args) {
        int [] arr={2,588,888,1000,11000};
        Random sc=new Random();
        //把奖池里面的顺序打乱

        for (int i = 0; i <arr.length ; i++) {
            //获取随机索引
            int randomIndex=sc.nextInt(arr.length);
            //拿着i跟随机索引上randomIndex的值进行交换
            int temp=arr[i];
            arr[i] = arr[randomIndex];
            arr[randomIndex]=temp;

        }

        //遍历奖池从0索引开始获取每一个奖项
        for (int i = 0; i < arr.length ; i++) {
            System.out.print(arr[i]+" ");
        }
    }
}
相关推荐
C雨后彩虹13 分钟前
ConcurrentHashMap入门:高并发场景的 HashMap替代方案
java·数据结构·哈希算法·集合·hashmap
weixin_4250230022 分钟前
Spring boot 2.7.18使用knife4j
java·spring boot·后端
产幻少年25 分钟前
面试题八股
java
wanghowie26 分钟前
01.08 Java基础篇|设计模式深度解析
java·开发语言·设计模式
scx2013100432 分钟前
20251201换根DP总结
算法·动态规划·换根dp
zd20057234 分钟前
STREAMS指南:环境及宿主相关微生物组研究中的技术报告标准
人工智能·python·算法
Data_agent38 分钟前
京东商品价格历史信息API使用指南
java·大数据·前端·数据库·python
TechNomad42 分钟前
排序算法:基数排序算法
算法·排序算法
Knight_AL42 分钟前
Java 17 新特性深度解析:记录类、密封类、模式匹配与增强的 switch 表达式对比 Java 8
java·开发语言
最贪吃的虎1 小时前
Spring Boot 自动装配(Auto-Configuration)深度实现原理全解析
java·运维·spring boot·后端·mysql