溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java如何實(shí)現(xiàn)隨機(jī)生成100個(gè)在1-150之間的數(shù)字并不出現(xiàn)重復(fù)

發(fā)布時(shí)間:2020-11-10 16:34:25 來源:億速云 閱讀:725 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關(guān)Java如何實(shí)現(xiàn)隨機(jī)生成100個(gè)在1-150之間的數(shù)字并不出現(xiàn)重復(fù),小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

核心代碼

import java.util.Arrays;

/**
 * 用Java產(chǎn)生100個(gè)1-150的數(shù)字
 */
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("+++++++++++++++++===================+++++++++++++");
		
		// 對結(jié)果數(shù)組排序后再輸出
		Arrays.sort(resultArr);
		for (Integer num : resultArr) {
			System.out.println(num);
		}
	}

	/**
	 * 產(chǎn)生隨機(jī)數(shù)字
	 * @param minNum 最小數(shù)字
	 * @param maxNum 最大數(shù)字
	 * @param numCount 產(chǎn)生的數(shù)字個(gè)數(shù)
	 * @return 結(jié)果數(shù)組
	 */
	public static int[] produceNum(int minNum, int maxNum, int numCount) {
		
		// 入?yún)⑿r?yàn)
		// 如果隨機(jī)數(shù)的個(gè)數(shù)大于產(chǎn)生隨機(jī)數(shù)的范圍;或最大數(shù)小于最小數(shù)
		// 直接返回null,說明入?yún)⒉环弦?
		if (numCount > (maxNum - minNum + 1) || maxNum < minNum) {
			return null;
		}
		
		// 存放結(jié)果的數(shù)組
		int[] resultArr = new int[numCount];
		
		// count 記錄已產(chǎn)生的隨機(jī)數(shù)的個(gè)數(shù)
		int count = 0;
		
		while(count < numCount) {
			
			// 產(chǎn)生隨機(jī)數(shù)
			int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
			
			// flag 定義本次產(chǎn)生的隨機(jī)數(shù)是否已在數(shù)組中
			boolean flag = true;
			
			// 遍歷數(shù)組中已產(chǎn)生的隨機(jī)數(shù)
			for (int i=0; i<count; i++) {
				
				// 同本次產(chǎn)生的隨機(jī)數(shù)最比較
				if (num == resultArr[i]) {
					
					// 如果已存在相同的值,則跳出for循環(huán),繼續(xù)外層的while循環(huán),產(chǎn)生下一個(gè)隨機(jī)數(shù)
					flag = false;
					break;
				}
			}
			
			// 如果本次產(chǎn)生的隨機(jī)數(shù)在數(shù)組中不存在,則將該隨機(jī)數(shù)存放在數(shù)組中
			if (flag) {
				resultArr[count] = num;
				
				// 數(shù)組中已產(chǎn)生的隨機(jī)數(shù)個(gè)數(shù)加1
				count++;
			}
		}
		
		return resultArr;
	}
}

代碼解讀

1 int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
Math.random() 產(chǎn)生的是0~1 之間的double類型的隨機(jī)數(shù)
Math.random() * 10 便會(huì)得到 0 ~ 10 之間的隨機(jī)數(shù),轉(zhuǎn)int后便是0 ~ 9;如果給 Math.random() * 10 + 1,便是1 ~ 11 之間的隨機(jī)數(shù),轉(zhuǎn)int便是1 ~ 10。
這里的1 相當(dāng)于程序中的最小值,11則為最大值。
這樣便得到了產(chǎn)生隨機(jī)數(shù)的 (int) (Math.random() * (maxNum - minNum)) + minNum

2 for (int i=0; i<count; i++) {
由于每次產(chǎn)生的num都是隨機(jī)的,所以無法保證重復(fù)的問題,所以只有通過去同已經(jīng)產(chǎn)生的存在數(shù)組中的數(shù)字去比較,相同,則重新產(chǎn)生,不同,則添加進(jìn)數(shù)組。

以上就是Java如何實(shí)現(xiàn)隨機(jī)生成100個(gè)在1-150之間的數(shù)字并不出現(xiàn)重復(fù),小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI