您好,登錄后才能下訂單哦!
本篇文章展示了java實現生成指定區間內n個不同的隨機數的方法,代碼簡明扼要容易理解,絕對能讓你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
實現方法:
先定義長度為n的數組,然后開始用while循環生成隨機數給數組賦值,在賦值之前需要先遍歷數組中已經存在的值,如果存在值相等的情況,則重新生成隨機數,不進行賦值,循環至定義的數組全部被賦值完。
示例如下:
/** * 功能:產生min-max中的n個不重復的隨機數 * * min:產生隨機數的其實位置 * mab:產生隨機數的最大位置 * n: 所要產生多少個隨機數 * */ public static int[] randomNumber(int min,int max,int n){ //判斷是否已經達到索要輸出隨機數的個數 if(n>(max-min+1) || max <min){ return null; } int[] result = new int[n]; //用于存放結果的數組 int count = 0; while(count <n){ int num = (int)(Math.random()*(max-min))+min; boolean flag = true; for(int j=0;j<count;j++){ if(num == result[j]){ flag = false; break; } } if(flag){ result[count] = num; count++; } } return result; }
利用Set的特性,元素不能重復
/** * 功能:隨機指定范圍內N個不重復的數 * * @param min 指定范圍最小值 * @param max 指定范圍最大值 * @param n 隨機數個數 */ public static int[] randomSet(int min, int max, int n) { Set<Integer> set = new HashSet<Integer>(); int[] array = new int[n]; for (; true;) { // 調用Math.random()方法 int num = (int) (Math.random() * (max - min)) + min; // 將不同的數存入HashSet中 set.add(num); // 如果存入的數小于指定生成的個數,則調用遞歸再生成剩余個數的隨機數,如此循環,直到達到指定大小 if (set.size() >= n) { break; } } int i = 0; for (int a : set) { array[i] = a; i++; } return array; }
先將生成的隨機數放入到set中,然后判斷set的大小,如果沒有超出需要的長度,繼續循環,如果已經超出,則跳出循環,并將set轉成數組。
上文描述的就是java實現生成指定區間內n個不同的隨機數的方法,具體使用情況還需要大家自己動手實驗使用過才能領會。如果想了解更多相關內容,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。