java生成不重复的随机数【某个范围0-10】或者【某个数组int[1,3,56,14,26,22,17]】

来源:互联网 发布:淘宝网电脑旺旺打不开 编辑:程序博客网 时间:2024/06/05 21:05

【java】废话不多说直接贴代码:


/** * 随机指定范围内N个不重复的数 * 最简单最基本的方法 * @param min 指定范围最小值 * @param max 指定范围最大值 * @param n 随机数个数 */public static int[] randomCommon(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 < n; j++) {if(num == result[j]){flag = false;break;}}if(flag){result[count] = num;count++;}}return result;}/** * 随机指定范围内N个不重复的数 * 利用HashSet的特征,只能存放不同的值 * @param min 指定范围最小值 * @param max 指定范围最大值 * @param n 随机数个数 * @param HashSet<Integer> set 随机数结果集 */public static void randomSet(int min, int max, int n, HashSet<Integer> set) {if (n > (max - min + 1) || max < min) {return;}for (int i = 0; i < n; i++) {// 调用Math.random()方法int num = (int) (Math.random() * (max - min)) + min;set.add(num);// 将不同的数存入HashSet中}int setSize = set.size();// 如果存入的数小于指定生成的个数,则调用递归再生成剩余个数的随机数,如此循环,直到达到指定大小if (setSize < n) {randomSet(min, max, n - setSize, set);// 递归}}/** * 随机指定范围内N个不重复的数 * 在初始化的无重复待选数组中随机产生一个数放入结果中, * 将待选数组被随机到的数,用待选数组(len-1)下标对应的数替换 * 然后从len-2里随机产生下一个随机数,如此类推 * @param max  指定范围最大值 * @param min  指定范围最小值 * @param n  随机数个数 * @return int[] 随机数结果集 */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[n];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个随机数 * @param data  数组 * @param n   随机数个数 * @return  int[] 随机数结果集 */public static int[] randomNoRepeat(int[] data1,int n){int[] result = new int[n];Random r = new Random();int irdm = 0;for(int i = 0; i < n; i ++) {irdm = r.nextInt(11 - i);//[3, 5, 6, 8, 9, 15, 18, 24, 27, 30, 32]result[i] = data1[irdm];if(i == (n-1)){break;}for(int j = irdm; j < 11 - i - 1; j ++) {data1[j] = data1[j + 1];}}return result;}public static void main(String[] args) {int[] reult1 = randomCommon(0,10,3);System.out.println("方式1:");for (int i : reult1) {System.out.print(i + ",");}System.out.println();System.out.println("方式2:");int[] reult2 = randomArray(0,10,3);for (int i : reult2) {System.out.print(i + ",");}System.out.println();System.out.println("方式3:");HashSet<Integer> set = new HashSet<Integer>();randomSet(0,10,3,set);for (int j : set) {System.out.print(j + ",");}System.out.println();System.out.println("方式4:");int[] data1 = {3, 5, 6, 8, 9, 15, 18, 24, 27, 30, 32};int[] reult3 = randomNoRepeat(data1,3);for (int i : reult3) {System.out.print(i + ",");}}

运行后结果:

方式1:
7,1,5,
方式2:
9,0,4,
方式3:
4,6,8,
方式4:
32,30,27,



=====基础很重要额==========

2015年3月27日 11:36:30

0 0