用Java產(chǎn)生100個(gè)1-150間不重復(fù)數(shù)字
核心代碼
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("+++++++++++++++++===================+++++++++++++");
// 對(duì)結(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,說(shuō)明入?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ī)的,所以無(wú)法保證重復(fù)的問(wèn)題,所以只有通過(guò)去同已經(jīng)產(chǎn)生的存在數(shù)組中的數(shù)字去比較,相同,則重新產(chǎn)生,不同,則添加進(jìn)數(shù)組。
相關(guān)文章
Spring Security在標(biāo)準(zhǔn)登錄表單中添加一個(gè)額外的字段
這篇文章主要介紹了Spring Security在標(biāo)準(zhǔn)登錄表單中添加一個(gè)額外的字段,我們將重點(diǎn)關(guān)注兩種不同的方法,以展示框架的多功能性以及我們可以使用它的靈活方式。 需要的朋友可以參考下2019-05-05
WebSocket實(shí)現(xiàn)聊天室業(yè)務(wù)
這篇文章主要為大家詳細(xì)介紹了WebSocket實(shí)現(xiàn)聊天室業(yè)務(wù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08
SpringBoot的@EnableAsync和@Async注解分析
這篇文章主要介紹了SpringBoot的@EnableAsync和@Async注解分析,Spring Boot是一個(gè)快速開(kāi)發(fā)框架,可以幫助開(kāi)發(fā)人員快速構(gòu)建基于Spring的應(yīng)用程序,需要的朋友可以參考下2023-07-07
淺析對(duì)Java關(guān)鍵字final和static的理解
本文主要給大家談?wù)勑【帉?duì)java關(guān)鍵字final和static的理解,本文給大家介紹的較詳細(xì),需要的朋友參考參考下2017-04-04
Java 使用keytool創(chuàng)建CA證書的操作
這篇文章主要介紹了Java 使用keytool創(chuàng)建CA證書的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
Java后臺(tái)判斷ajax請(qǐng)求及處理過(guò)程詳解
這篇文章主要介紹了Java后臺(tái)判斷ajax請(qǐng)求及處理過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
通過(guò)實(shí)例了解Java jdk和jre的區(qū)別
這篇文章主要介紹了通過(guò)實(shí)例了解Java jdk和jre的區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
struts2通過(guò)action返回json對(duì)象
struts2通過(guò)action返回json對(duì)象其實(shí)很簡(jiǎn)單的,首先我們需要引入jar包,然后在寫一個(gè)簡(jiǎn)單的action就好了,接下來(lái)通過(guò)本文給大家介紹struts2通過(guò)action返回json對(duì)象的方法,感興趣的朋友一起看看吧2016-09-09

