本篇文章展示了java实现生成指定区间内n个不同的随机数的方法,代码简明扼要容易理解,绝对能让你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
实现方法:
先定义长度为n的数组,然后开始用while循环生成随机数给数组赋值,在赋值之前需要先遍历数组中已经存在的值,如果存在值相等的情况,则重新生成随机数,不进行赋值,循环至定义的数组全部被赋值完。
示例如下:
/**
* 功能:产生min-max中的n个不重复的随机数
*
* min:产生随机数的其实位置
* mab:产生随机数的最大位置
* n: 所要产生多少个随机数
*
*/
public static int[] randomNumber(int min,int max,int n){
//判断是否已经达到索要输出随机数的个数
if(n>(max-min+1) || max <min){
return null;
}
int[] result = new int[n]; //用于存放结果的数组
int count = 0;
while(count <n){
int num = (int)(Math.random()*(max-min))+min;
boolean flag = true;
for(int j=0;j<count;j++){
if(num == result[j]){
flag = false;
break;
}
}
if(flag){
result[count] = num;
count++;
}
}
return result;
}
利用Set的特性,元素不能重复
/**
* 功能:随机指定范围内N个不重复的数
*
* @param min 指定范围最小值
* @param max 指定范围最大值
* @param n 随机数个数
*/
public static int[] randomSet(int min, int max, int n) {
Set<Integer> set = new HashSet<Integer>();
int[] array = new int[n];
for (; true;) {
// 调用Math.random()方法
int num = (int) (Math.random() * (max - min)) + min;
// 将不同的数存入HashSet中
set.add(num);
// 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小
if (set.size() >= n) {
break;
}
}
int i = 0;
for (int a : set) {
array[i] = a;
i++;
}
return array;
}
先将生成的随机数放入到set中,然后判断set的大小,如果没有超出需要的长度,继续循环,如果已经超出,则跳出循环,并将set转成数组。
上文描述的就是java实现生成指定区间内n个不同的随机数的方法,具体使用情况还需要大家自己动手实验使用过才能领会。如果想了解更多相关内容,欢迎关注亿速云行业资讯频道!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。