JAVA隨機數之多種方法從給定范圍內隨機N個不重復數


一、JAVA中生成隨機數的方式

 

     1、在j2se中使用Math.random()令系統隨機選取一個0~1之間的double類型小數,將其乘以一個數,比如25,就能得到一個0~25范圍內的隨機數,這個在j2me中沒有;    

Java代碼  
  1. int randomNumber = (int) Math.round(Math.random()*(max-min)+min);  

 

     2、在System類中有一個currentTimeMillis()方法,這個方法返回從1970年1月1號0點0分0秒到目前的一個long型的毫秒 數,可作為一個隨機數,還可以將其對某些數取模,就能限制隨機數的范圍;此方式在循環中同時產生多個隨機數時,會是相同的值,有一定的局限性!  

Java代碼  
  1. long randomNum = System.currentTimeMillis();  
  2. int randomNumber = (int) randomNum%(max-min)+min;  

 

     3、使用java.util.Random類來產生一個隨機數發生器,這個也是我們在j2me的程序里經常用的一個取隨機數的方法。它有兩種形式的構造函 數,分別是Random()和Random(long seed)。Random()使用當前時間即System.currentTimeMillis()作為發生器的種子,Random(long seed)使用指定的seed作為發生器的種子。隨機數發生器(Random)對象產生以后,通過調用不同的method:nextInt()、 nextLong()、nextFloat()、nextDouble()等獲得不同類型隨機數。 如果兩個Random對象使用相同的種子(比如都是25),並且以相同的順序調用相同的函數,那它們返回值完全相同。    

Java代碼  
  1. Random random = new Random();  
  2. int randomNumber =  random.nextInt(max)%(max-min+1) + min;  

 

 

二、隨機給定范圍內N個不重復的數

 

    1、方法一:最簡單最易理解的兩重循環去重  

Java代碼  
  1. /** 
  2.  * 隨機指定范圍內N個不重復的數 
  3.  * 最簡單最基本的方法 
  4.  * @param min 指定范圍最小值 
  5.  * @param max 指定范圍最大值 
  6.  * @param n 隨機數個數 
  7.  */  
  8. public static int[] randomCommon(int min, int max, int n){  
  9.     if (n > (max - min + 1) || max < min) {  
  10.            return null;  
  11.        }  
  12.     int[] result = new int[n];  
  13.     int count = 0;  
  14.     while(count < n) {  
  15.         int num = (int) (Math.random() * (max - min)) + min;  
  16.         boolean flag = true;  
  17.         for (int j = 0; j < n; j++) {  
  18.             if(num == result[j]){  
  19.                 flag = false;  
  20.                 break;  
  21.             }  
  22.         }  
  23.         if(flag){  
  24.             result[count] = num;  
  25.             count++;  
  26.         }  
  27.     }  
  28.     return result;  
  29. }  

    

    2、方法二:利用HashSet的特征,只能存放不同的值  

Java代碼  
  1. /** 
  2.  * 隨機指定范圍內N個不重復的數 
  3.  * 利用HashSet的特征,只能存放不同的值 
  4.  * @param min 指定范圍最小值 
  5.  * @param max 指定范圍最大值 
  6.  * @param n 隨機數個數 
  7.  * @param HashSet<Integer> set 隨機數結果集 
  8.  */  
  9.    public static void randomSet(int min, int max, int n, HashSet<Integer> set) {  
  10.        if (n > (max - min + 1) || max < min) {  
  11.            return;  
  12.        }  
  13.        for (int i = 0; i < n; i++) {  
  14.            // 調用Math.random()方法  
  15.            int num = (int) (Math.random() * (max - min)) + min;  
  16.            set.add(num);// 將不同的數存入HashSet中  
  17.        }  
  18.        int setSize = set.size();  
  19.        // 如果存入的數小於指定生成的個數,則調用遞歸再生成剩余個數的隨機數,如此循環,直到達到指定大小  
  20.        if (setSize < n) {  
  21.         randomSet(min, max, n - setSize, set);// 遞歸  
  22.        }  
  23.    }  

 

     3、方法三:排除已隨機到的數  

Java代碼  
  1. /** 
  2.  * 隨機指定范圍內N個不重復的數 
  3.  * 在初始化的無重復待選數組中隨機產生一個數放入結果中, 
  4.  * 將待選數組被隨機到的數,用待選數組(len-1)下標對應的數替換 
  5.  * 然后從len-2里隨機產生下一個隨機數,如此類推 
  6.  * @param max  指定范圍最大值 
  7.  * @param min  指定范圍最小值 
  8.  * @param n  隨機數個數 
  9.  * @return int[] 隨機數結果集 
  10.  */  
  11. public static int[] randomArray(int min,int max,int n){  
  12.     int len = max-min+1;  
  13.       
  14.     if(max < min || n > len){  
  15.         return null;  
  16.     }  
  17.       
  18.     //初始化給定范圍的待選數組  
  19.     int[] source = new int[len];  
  20.        for (int i = min; i < min+len; i++){  
  21.         source[i-min] = i;  
  22.        }  
  23.          
  24.        int[] result = new int[n];  
  25.        Random rd = new Random();  
  26.        int index = 0;  
  27.        for (int i = 0; i < result.length; i++) {  
  28.         //待選數組0到(len-2)隨機一個下標  
  29.            index = Math.abs(rd.nextInt() % len--);  
  30.            //將隨機到的數放入結果集  
  31.            result[i] = source[index];  
  32.            //將待選數組中被隨機到的數,用待選數組(len-1)下標對應的數替換  
  33.            source[index] = source[len];  
  34.        }  
  35.        return result;  
  36. }  

  

    調用實例:

Java代碼  
  1.     public static void main(String[] args) {  
  2.     int[] reult1 = randomCommon(20,50,10);  
  3.     for (int i : reult1) {  
  4.         System.out.println(i);  
  5.     }  
  6.       
  7.     int[] reult2 = randomArray(20,50,10);  
  8.     for (int i : reult2) {  
  9.         System.out.println(i);  
  10.     }  
  11.       
  12.     HashSet<Integer> set = new HashSet<Integer>();  
  13.     randomSet(20,50,10,set);  
  14.        for (int j : set) {  
  15.         System.out.println(j);  
  16.     }  
  17. }  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM