在此之前我使用Java的數(shù)組實現(xiàn)了產(chǎn)生N-M之間的不重復(fù)的隨機數(shù),下面是使用數(shù)列ArrayList實現(xiàn)同樣的功能,代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/** * 隨機生成 N--M,N個不重復(fù)隨機數(shù) 使用ArrayList * * @param startRange 起始數(shù)字 * @param endRange 終止數(shù)字 * @param count 個數(shù) */ public static ArrayList<Integer> getRandom( int startRange, int endRange, int count) { ArrayList<Integer> arr = new ArrayList<>(); for ( int i = 0 ; i < count; i++) { arr.add((( int ) (Math.random() * (endRange - startRange + 1 ) + startRange))); for ( int j = 0 ; j < i; j++) { if (arr.get(i) == arr.get(j)) { arr.remove(i); i--; break ; } } } return arr; } |
這個實現(xiàn)的原理和使用數(shù)組基本一致,但是需要注意的幾點,我這里是使用的一個返回序列,參數(shù)只有起始值、終值和個數(shù),然后定義了一個ArrayList數(shù)列,使用數(shù)列的add方法,接收每一個產(chǎn)生的隨機數(shù),并使用For循環(huán)進行判斷是否重復(fù),如果重復(fù)外循環(huán) i -- ,但是這里需要注意的是:此時ArrayList里面已經(jīng)存放了當(dāng)前的重復(fù)的值了,所以不能只用 i --,還需要使用梳理的remove方法將此不符合條件的數(shù)移除,這里是需要注意的,如果不寫著一句,在小的范圍內(nèi)生成的隨機數(shù)很可能會出現(xiàn)死循環(huán)。
下面是成功運行的截圖:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:https://www.cnblogs.com/lwl80/p/13356470.html