import java.util.Random;
代码演示:
package com.lbj.javase.random;import java.util.Random;public class RandomTest01 {public static void main(String[] args) {//创建随机数对象Random random=new Random();int num1=random.nextInt();System.out.println(num1);//nextInt翻译为:下一个int类型的数据是101,表示只能取到100,不包括101int num2=random.nextInt(101);System.out.println(num2);}
}
第一次运行结果:
335893798
64
第N次运行结果:
-2024089022
53
题目:
设置一个5长度的一维数组,然后往里面存入随机数据,要求:随机的数据不能在数组中重复
代码演示:
package com.lbj.javase.random;import java.util.Arrays;
import java.util.Random;public class RandomTest02 {public static void main(String[] args) {//准备一个长度为5的一维数组,动态创建的数组里面默认值都是0int[] arr=new int[5];//为了避免扰乱数组中的0是数组的还是自动生成的随机数的0,我们用循环赋值-1for (int i = 0; i <arr.length; i++) {arr[i]=-1;}//创建Random对象Random random=new Random();//循环,生成随机数int index=0;while (index<arr.length){int num=random.nextInt(101);//判断随机数是否重复if (!contains(arr,num)){arr[index]=num;index++;}}//遍历存了数据的数组for (int i = 0; i <arr.length; i++) {System.out.println(arr[i]);}}/**** @param x 数组* @param y 元素* @return true表示包含,false表示不包含*///单独写一个方法,这个方法专门用来判断数组中是否包含某个元素public static boolean contains(int[] x,int y){/* 这个方案有bug,因为排序//对数组进行升序Arrays.sort(x);//二分法查找// >=0证明存在int index=Arrays.binarySearch(x,y);return index>=0;*/for (int i = 0; i <x.length; i++) {if(x[i]==y){return true;}}return false;}
}