随机生成大小为100的范围是100-1000的不重复的数组
首先想到的是用Set保证不重复,如果重复就重新生成随机数。。
但是这样可能复杂度会很高,不稳定。
面试官问还有什么办法的时候,我真是毫无头绪。
一面试就智商下线 //说的好像平时在线是的
QAQ
查了下题解:生成N个不相等的随机数
第一个方法是我写的暴力 T^T
第二个就是用一个数组记录还未用到的数字 然后每次随即下标就好了 这样保证一定是不重复的
import java.util.HashSet; import java.util.Random; import java.util.Set; public class RandomArray { Random rand = new Random(); public int[] getArray1(int n, int low, int high) { int[] arr = new int[n]; Set<Integer> set = new HashSet<>(); for (int i = 0; i < n; ++i) { int x = randomInt(low, high); while (set.contains(x)) { x = randomInt(low, high); } set.add(x); arr[i] = x; } return arr; } private int randomInt(int low, int high) { return rand.nextInt(high - low + 1) + low; } public int[] getArray2(int n, int low, int high) { int[] arr = new int[n]; int length = high - low + 1; int[] notUseNum = new int[length]; // 先将要生成的数放到数组中 然后每次在数组中随机取一个 for (int i = 0; i < length; ++i) { notUseNum[i] = i + low; } for (int i = 0; i < n; ++i) { // 在数组中随即选取一个数字 int pos = rand.nextInt(length); arr[i] = notUseNum[pos]; // 把用过的删除 把最后的挪到该位置 这样保证要取的数字位置都是连续的 notUseNum[pos] = notUseNum[--length]; } return arr; } public static void main(String[] args) { RandomArray ra = new RandomArray(); int[] arr = ra.getArray1(100, 100, 1000); for (int i: arr) System.out.println(i); int[] arr2 = ra.getArray2(10, 1, 10); for (int i: arr2) System.out.println(i); } }