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]+" ");
        }
    }
}
相关推荐
Solar20258 小时前
机械制造业TOB企业获客软件选型指南:从挑战到解决方案的深度解析
java·大数据·服务器·架构·云计算
千金裘换酒8 小时前
LeetCode 二叉树的最大深度 递归+层序遍历
算法·leetcode·职场和发展
爱敲代码的TOM8 小时前
详解一致性哈希算法
算法·哈希算法
lzllzz239 小时前
递归的理解
算法·深度优先·图论
星火开发设计9 小时前
C++ stack 全面解析与实战指南
java·数据结构·c++·学习·rpc··知识
宋情写9 小时前
JavaAI06-SpringAI
java·人工智能
Hello.Reader9 小时前
Flink Avro Format Java / PyFlink 读写、Schema 细节与坑点总结
java·python·flink
人道领域9 小时前
【零基础学java】(反射)
java·开发语言
小O的算法实验室9 小时前
2024年IEEE TITS SCI2区TOP,考虑无人机能耗与时间窗的卡车–无人机协同路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
派森先生9 小时前
排序算法-选择排序
算法·排序算法