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]+" ");
        }
    }
}
相关推荐
苹果醋31 小时前
React源码02 - 基础知识 React API 一览
java·运维·spring boot·mysql·nginx
Hello.Reader1 小时前
深入解析 Apache APISIX
java·apache
菠萝蚊鸭2 小时前
Dhatim FastExcel 读写 Excel 文件
java·excel·fastexcel
旭东怪2 小时前
EasyPoi 使用$fe:模板语法生成Word动态行
java·前端·word
007php0072 小时前
Go语言zero项目部署后启动失败问题分析与解决
java·服务器·网络·python·golang·php·ai编程
∝请叫*我简单先生2 小时前
java如何使用poi-tl在word模板里渲染多张图片
java·后端·poi-tl
ssr——ssss2 小时前
SSM-期末项目 - 基于SSM的宠物信息管理系统
java·ssm
一棵星2 小时前
Java模拟Mqtt客户端连接Mqtt Broker
java·开发语言
鲤籽鲲3 小时前
C# Random 随机数 全面解析
android·java·c#
xiaoshiguang33 小时前
LeetCode:222.完全二叉树节点的数量
算法·leetcode