Java 随机数

Random

  Random random = new Random();

  

import java.util.Random;

public class RandomTest01 {
    public static void main(String[] args) {
        // 创建随机数对象
        Random random = new Random();
        // 随机产生一个int类型取值范围内的数字。
        int num1 = random.nextInt();

        System.out.println(num1);
        // 产生[0~100]之间的随机数。不能产生101。
        // nextInt翻译为:下一个int类型的数据是101,表示只能取到100.
        int num2 = random.nextInt(101); //不包括101
        System.out.println(num2);

    }

}
import java.util.Arrays;
import java.util.Random;

/*
编写程序,生成5个不重复的随机数[0-100]。重复的话重新生成。
最终生成的5个随机数放到数组中,要求数组中这5个随机数不重复。
 */
public class RandomTest02 {
    public static void main(String[] args) {

        // 创建Random对象
        Random random = new Random();

        // 准备一个长度为5的一维数组。
        int[] arr = new int[5]; // 默认值都是0
        for(int i = 0; i < arr.length; i++){
            arr[i] = -1;
        }

        // 循环,生成随机数
        int index = 0;
        while(index < arr.length){
            // 生成随机数
            //int num = random.nextInt(101);
            //int num = random.nextInt(6); // 只能生成[0-5]的随机数!
            int num = random.nextInt(4); // 只能生成[0-3]的随机数!永远都有重复的,永远都凑不够5个。
            System.out.println("生成的随机数:" + num);
            // 判断arr数组中有没有这个num
            // 如果没有这个num,就放进去。
            if(!contains(arr, num)){
                arr[index++] = num;
            }
        }

        // 遍历以上的数组
        for(int i = 0; i < arr.length; i++){
            System.out.println(arr[i]);
        }
    }

    /**
     * 单独编写一个方法,这个方法专门用来判断数组中是否包含某个元素
     * @param arr 数组
     * @param key 元素
     * @return true表示包含,false表示不包含。
     */
    public static boolean contains(int[] arr, int key){
        /*
        // 这个方案bug。(排序出问题了。)
        // 对数组进行升序
        //Arrays.sort(arr);
        // 进行二分法查找
        // 二分法查找的结果 >= 0说明,这个元素找到了,找到了表示存在!
        //return Arrays.binarySearch(arr, key) >= 0;
         */

        for(int i = 0; i < arr.length; i++){
            if(arr[i] == key){
                // 条件成立了表示包含,返回true
                return true;
            }
        }
        // 这个就表示不包含!
        return false;
    }

}

 

posted @ 2020-09-09 00:01  一叶扁舟,乘风破浪  阅读(638)  评论(0编辑  收藏  举报