最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網營銷解決方案
Java如何實現(xiàn)隨機生成100個在1-150之間的數(shù)字并不出現(xiàn)重復

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

創(chuàng)新互聯(lián)公司是專業(yè)的龍亭網站建設公司,龍亭接單;提供成都網站設計、網站制作、外貿營銷網站建設,網頁設計,網站設計,建網站,PHP網站建設等專業(yè)做網站服務;采用PHP框架,可快速的進行龍亭網站開發(fā)網頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網站,專業(yè)的做網站團隊,希望更多企業(yè)前來合作!

核心代碼

import java.util.Arrays;

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

	/**
	 * 產生隨機數(shù)字
	 * @param minNum 最小數(shù)字
	 * @param maxNum 最大數(shù)字
	 * @param numCount 產生的數(shù)字個數(shù)
	 * @return 結果數(shù)組
	 */
	public static int[] produceNum(int minNum, int maxNum, int numCount) {
		
		// 入參校驗
		// 如果隨機數(shù)的個數(shù)大于產生隨機數(shù)的范圍;或最大數(shù)小于最小數(shù)
		// 直接返回null,說明入參不符合要求
		if (numCount > (maxNum - minNum + 1) || maxNum < minNum) {
			return null;
		}
		
		// 存放結果的數(shù)組
		int[] resultArr = new int[numCount];
		
		// count 記錄已產生的隨機數(shù)的個數(shù)
		int count = 0;
		
		while(count < numCount) {
			
			// 產生隨機數(shù)
			int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
			
			// flag 定義本次產生的隨機數(shù)是否已在數(shù)組中
			boolean flag = true;
			
			// 遍歷數(shù)組中已產生的隨機數(shù)
			for (int i=0; i

代碼解讀

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

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

以上就是Java如何實現(xiàn)隨機生成100個在1-150之間的數(shù)字并不出現(xiàn)重復,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


名稱欄目:Java如何實現(xiàn)隨機生成100個在1-150之間的數(shù)字并不出現(xiàn)重復
文章來源:http://fisionsoft.com.cn/article/gchdjh.html