核心代码
import java.util.Arrays;
public class RandomTest {
public static void main(String[] args) {
int[] resultArr = produceNum(1, 150, 100);
for (Integer num : resultArr) {
System.out.println(num);
}
System.out.println("+++++++++++++++++===================+++++++++++++");
// 对结果数组排序后再输出
Arrays.sort(resultArr);
for (Integer num : resultArr) {
System.out.println(num);
}
}
public static int[] produceNum(int minNum, int maxNum, int numCount) {
// 入参校验
// 如果随机数的个数大于产生随机数的范围;或最大数小于最小数
// 直接返回null,说明入参不符合要求
if (numCount > (maxNum - minNum + 1) || maxNum < minNum) {
return null;
}
// 存放结果的数组
int[] resultArr = new int[numCount];
// count 记录已产生的随机数的个数
int count = 0;
while(count < numCount) {
// 产生随机数
int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
// flag 定义本次产生的随机数是否已在数组中
boolean flag = true;
// 遍历数组中已产生的随机数
for (int i=0; i
代码解读
1 int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
Math.random() 产生的是0~1 之间的double类型的随机数
Math.random() * 10 便会得到 0 ~ 10 之间的随机数,转int后便是0 ~ 9;如果给 Math.random() * 10 + 1,便是1 ~ 11 之间的随机数,转int便是1 ~ 10。
这里的1 相当于程序中的最小值,11则为最大值。
这样便得到了产生随机数的 (int) (Math.random() * (maxNum - minNum)) + minNum
2 for (int i=0; i
由于每次产生的num都是随机的,所以无法保证重复的问题,所以只有通过去同已经产生的存在数组中的数字去比较,相同,则重新产生,不同,则添加进数组。



