Java的ArrayList實現隨機生成N-M之間N個不重複的隨機數
阿新 • • 發佈:2020-07-21
在此之前我使用Java的陣列實現了產生N-M之間的不重複的隨機數,下面是使用數列ArrayList實現同樣的功能,程式碼如下:
1 /** 2 * 隨機生成 N--M,N個不重複隨機數 使用ArrayList 3 * 4 * @param startRange 起始數字 5 * @param endRange 終止數字 6 * @param count 個數 7 */ 8 public static ArrayList<Integer> getRandom(int startRange, intendRange, int count) { 9 ArrayList<Integer> arr = new ArrayList<>(); 10 for (int i = 0; i < count; i++) { 11 arr.add(((int) (Math.random() * (endRange - startRange + 1) + startRange))); 12 for (int j = 0; j < i; j++) { 13 if (arr.get(i) == arr.get(j)) {14 arr.remove(i); 15 i--; 16 break; 17 } 18 } 19 } 20 return arr; 21 }
這個實現的原理和使用陣列基本一致,但是需要注意的幾點,我這裡是使用的一個返回序列,引數只有起始值、終值和個數,然後定義了一個ArrayList數列,使用數列的add方法,接收每一個產生的隨機數,並使用For迴圈進行判斷是否重複,如果重複外迴圈 i -- ,但是這裡需要注意的是:此時ArrayList裡面已經存放了當前的重複的值了,所以不能只用 i --,還需要使用梳理的remove方法將此不符合條件的數移除,這裡是需要注意的,如果不寫著一句,在小的範圍內生成的隨機數很可能會出現死迴圈。
下面是成功執行的截圖: