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]+" ");
        }
    }
}
相关推荐
Wect8 小时前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
Re_zero8 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记8 小时前
Spring Boot条件注解详解
java·spring boot
NAGNIP20 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5511 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
颜酱1 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉