JAVA实现指定区间取N个不重复随机数
2018-03-17 11:15
369 查看
近日在面试中多次被问到从规定区间取N个随机数的问题,所以今日将实现方式整理一下,代码如下:
传统双重循环去重的方式
这种方式比较好理解,先定义长度为n的数组,然后开始用while循环生成随机数给数组赋值,在赋值之前需要先遍历数组中已经存在的值,如果存在值相等的情况,则重新生成随机数,不进行赋值,循环至定义的数组全部被赋值完。
利用Set的特性,元素不能重复
先将生成的随机数放入到set中,然后判断set的大小,如果没有超出需要的长度,继续循环,如果已经超出,则跳出循环,并将set转成数组。
排除已随机到的数
先生成两个数组,一个是已经赋值完的待选数组,值为最小值到最大值,然后再初始化一个长度的目标随机数个数的目标数组,然后将赋值完数据中的值用随机下标复制到目标数组进行复制,再将待选数组中被随机到的数,用待选数组长度n-1下标对应的数替换,避免再次重复取值。
传统双重循环去重的方式
/** * 功能:产生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 ; //用于存放结果的数组 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; }
这种方式比较好理解,先定义长度为n的数组,然后开始用while循环生成随机数给数组赋值,在赋值之前需要先遍历数组中已经存在的值,如果存在值相等的情况,则重新生成随机数,不进行赋值,循环至定义的数组全部被赋值完。
利用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 ; 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转成数组。
排除已随机到的数
/** * 功能:随机指定范围内N个不重复的数 * * @param max 指定范围最大值 * @param min 指定范围最小值 * @param n 随机数个数 */ public static int[] randomArray(int min, int max, int n) { int len = max - min + 1; if (max < min || n > len) { return null; } // 初始化给定范围的待选数组 int[] source = new int[len]; for (int i = min; i < min + len; i++) { source[i - min] = i; } int[] result = new int ; Random rd = new Random(); int index = 0; for (int i = 0; i < result.length; i++) { // 待选数组0到(len-2)随机一个下标 index = Math.abs(rd.nextInt() % len--); // 将随机到的数放入结果集 result[i] = source[index]; // 将待选数组中被随机到的数,用待选数组(len-1)下标对应的数替换 source[index] = source[len]; } return result; }
先生成两个数组,一个是已经赋值完的待选数组,值为最小值到最大值,然后再初始化一个长度的目标随机数个数的目标数组,然后将赋值完数据中的值用随机下标复制到目标数组进行复制,再将待选数组中被随机到的数,用待选数组长度n-1下标对应的数替换,避免再次重复取值。
相关文章推荐
- java生成指定个数及区间范围的不重复随机数存入数组中
- 算法--生成m个指定范围的不重复随机数的三种方法分析(Java实现)
- JAVA生成指定位数不重复的随机数,随机数含0-9、A-Z
- Java编程实现从给定范围内随机N个不重复数生成随机数的方法小结
- 使用java的html解析器jsoup和jQuery实现一个自动重复抓取任意网站页面指定元素的web应用
- Java生成指定位数不重复随机数
- Java获取随机数获取制定范围指定个数不重复的随机数
- JAVA生成指定位数不重复的随机数,随机数含0-9、A-Z
- java中Random类生成指定区间的随机数_区间的设置公式
- Java中在特定区间产生随机数 (2009-03-26 13:31:49)转载▼ 标签: 杂谈 生成指定范围内的随机数 这个是最常用的技术之一。程序员希望通过随机数的方式来处理众多的业务逻辑,测试
- 使用java的html解析器jsoup和jQuery实现一个自动重复抓取任意网站页面指定元素的...
- Java 生成任意位数永不重复的随机数策略实现
- Java随机生成指定区间的随机数
- 高效产生一组不重复的随机数(受编程珠矶启示)java实现
- 生成指定范围内无重复的随机乱序数组(JAVA实现/时间复杂度为O(n))
- Java 生成任意位数永不重复的随机数策略实现
- 使用java的html解析器jsoup和jQuery实现一个自动重复抓取任意网站页面指定元素的web应用
- 使用java的html解析器jsoup和jQuery实现一个自动重复抓取任意网站页面指定元素的web应用
- Java实现生成n个不重复的随机数
- 高效产生一组不重复的随机数(受编程珠矶启示)java实现