java產生任意範圍內不重複的隨機數
阿新 • • 發佈:2019-02-09
n:需要的隨機數的數目
min:下限;
max:上限
import java.util.* ; class Tester { public static void main(String args[]) { HashSet<Integer> set = new HashSet<Integer>() ; int min = 1 ; int max = 50 ; Ran(min,max,10,set) ; Iterator it = set.iterator() ; System.out.println(set) ; } public static void Ran(int min,int max,int n,HashSet<Integer> set) { if(n > max-min+1 || max<min) { return ; } for(int i = 0 ; i<n ;i++) { int num = (int) (Math.random()*(max-min)) + min ; set.add(num) ; } int setSize = set.size() ; if(setSize < n) { Ran(min,max,n-setSize,set) ; } } }
這種寫法在隨機數數目特別多的時候不好用,