Java產生100個1-150間不重復數字

cm54 9年前發布 | 934 次閱讀 Java

    import java.util.Arrays;

/** 
 * 用Java產生100個1-150的數字 
 */  
public class RandomTest {  

    public static void main(String[] args) {  
        int[] resultArr = produceNum(1, 150, 100);  
        for (Integer num : resultArr) {  
            System.out.println(num);  
        }  

        System.out.println("+++++++++++++++++===================+++++++++++++");  

        // 對結果數組排序后再輸出  
        Arrays.sort(resultArr);  
        for (Integer num : resultArr) {  
            System.out.println(num);  
        }  
    }  

    /** 
     * 產生隨機數字 
     * @param minNum 最小數字 
     * @param maxNum 最大數字 
     * @param numCount 產生的數字個數 
     * @return 結果數組 
     */  
    public static int[] produceNum(int minNum, int maxNum, int numCount) {  

        // 入參校驗  
        // 如果隨機數的個數大于產生隨機數的范圍;或最大數小于最小數  
        // 直接返回null,說明入參不符合要求  
        if (numCount > (maxNum - minNum + 1) || maxNum < minNum) {  
            return null;  
        }  

        // 存放結果的數組  
        int[] resultArr = new int[numCount];  

        // count 記錄已產生的隨機數的個數  
        int count = 0;  

        while(count < numCount) {  

            // 產生隨機數  
            int num = (int) (Math.random() * (maxNum - minNum)) + minNum;  

            // flag 定義本次產生的隨機數是否已在數組中  
            boolean flag = true;  

            // 遍歷數組中已產生的隨機數  
            for (int i=0; i<count; i++) {  

                // 同本次產生的隨機數最比較  
                if (num == resultArr[i]) {  

                    // 如果已存在相同的值,則跳出for循環,繼續外層的while循環,產生下一個隨機數  
                    flag = false;  
                    break;  
                }  
            }  

            // 如果本次產生的隨機數在數組中不存在,則將該隨機數存放在數組中  
            if (flag) {  
                resultArr[count] = num;  

                // 數組中已產生的隨機數個數加1  
                count++;  
            }  
        }  

        return resultArr;  
    }  
}  </pre> 


代碼解讀

1  int num = (int) (Math.random() * (maxNum - minNum)) + minNum;

Math.random() 產生的是0~1 之間的double類型的隨機數

Math.random() * 10 便會得到 0 ~ 10 之間的隨機數,轉int后便是0 ~ 9;如果給 Math.random() * 10 + 1,便是1 ~ 11 之間的隨機數,轉int便是1 ~ 10。

這里的1 相當于程序中的最小值,11則為最大值。

這樣便得到了產生隨機數的 (int) (Math.random() * (maxNum - minNum)) + minNum


for (int i=0; i<count; i++) {

由于每次產生的num都是隨機的,所以無法保證重復的問題,所以只有通過去同已經產生的存在數組中的數字去比較,相同,則重新產生,不同,則添加進數組。

 本文由用戶 cm54 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!