随机数

65 阅读2分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第N天,点击查看活动详情

哈喽,大家好!我是Why,一名在读学生,目前刚刚开始进入自己的编程学习生涯。虽然学习起步较晚,但我坚信做了才有0或1的可能。学了一段时间以后也是选择在掘金上分享自己的日常笔记,也希望能够在众多道友的大家庭中打成一片。 本文主要讲解随机数,如果大家读后觉得有用的话,还请大家多多支持博主:欢迎 ❤️点赞👍、收藏⭐、留言💬 ✨✨✨个人主页:JinHuan

随机数

 java.util包下有有个Random类型
 可以用来处理随机数
 默认随机数范围
     [0~100]之间的随机数。不能产生101。
             int num = random.nextInt(6); // 只能生成[0-5]的随机数!
             int num = random.nextInt(4); // 只能生成[0-3]的随机数!

示例:

 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;
     }
 ​
 }