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,不包括101
int 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的一维数组,动态创建的数组里面默认值都是0
int[] arr=new int[5];
//为了避免扰乱数组中的0是数组的还是自动生成的随机数的0,我们用循环赋值-1
for (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;
}
}