欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用Java產生100個1-150間不重復數(shù)字

 更新時間:2017年02月21日 23:10:00   投稿:mdxy-dxy  
這篇文章主要介紹了用Java產生100個1-150間不重復數(shù)字,需要的朋友可以參考下

核心代碼

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) {
		
		// 入?yún)⑿r?
		// 如果隨機數(shù)的個數(shù)大于產生隨機數(shù)的范圍;或最大數(shù)小于最小數(shù)
		// 直接返回null,說明入?yún)⒉环弦?
		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<count; i++) {
				
				// 同本次產生的隨機數(shù)最比較
				if (num == resultArr[i]) {
					
					// 如果已存在相同的值,則跳出for循環(huán),繼續(xù)外層的while循環(huán),產生下一個隨機數(shù)
					flag = false;
					break;
				}
			}
			
			// 如果本次產生的隨機數(shù)在數(shù)組中不存在,則將該隨機數(shù)存放在數(shù)組中
			if (flag) {
				resultArr[count] = num;
				
				// 數(shù)組中已產生的隨機數(shù)個數(shù)加1
				count++;
			}
		}
		
		return resultArr;
	}
}

代碼解讀

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<count; i++) {
由于每次產生的num都是隨機的,所以無法保證重復的問題,所以只有通過去同已經產生的存在數(shù)組中的數(shù)字去比較,相同,則重新產生,不同,則添加進數(shù)組。

相關文章

  • Spring Security在標準登錄表單中添加一個額外的字段

    Spring Security在標準登錄表單中添加一個額外的字段

    這篇文章主要介紹了Spring Security在標準登錄表單中添加一個額外的字段,我們將重點關注兩種不同的方法,以展示框架的多功能性以及我們可以使用它的靈活方式。 需要的朋友可以參考下
    2019-05-05
  • WebSocket實現(xiàn)聊天室業(yè)務

    WebSocket實現(xiàn)聊天室業(yè)務

    這篇文章主要為大家詳細介紹了WebSocket實現(xiàn)聊天室業(yè)務,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • Java內存溢出場景及解決方案

    Java內存溢出場景及解決方案

    內存溢出是Java應用開發(fā)中常見的問題,但通過合理的代碼優(yōu)化、內存管理以及JVM參數(shù)調整,我們可以有效地避免和解決這類問題,這篇文章主要介紹了Java內存溢出場景及解決辦法,需要的朋友可以參考下
    2024-04-04
  • SpringBoot的@EnableAsync和@Async注解分析

    SpringBoot的@EnableAsync和@Async注解分析

    這篇文章主要介紹了SpringBoot的@EnableAsync和@Async注解分析,Spring Boot是一個快速開發(fā)框架,可以幫助開發(fā)人員快速構建基于Spring的應用程序,需要的朋友可以參考下
    2023-07-07
  • 淺析對Java關鍵字final和static的理解

    淺析對Java關鍵字final和static的理解

    本文主要給大家談談小編對java關鍵字final和static的理解,本文給大家介紹的較詳細,需要的朋友參考參考下
    2017-04-04
  • Java 使用keytool創(chuàng)建CA證書的操作

    Java 使用keytool創(chuàng)建CA證書的操作

    這篇文章主要介紹了Java 使用keytool創(chuàng)建CA證書的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • Java后臺判斷ajax請求及處理過程詳解

    Java后臺判斷ajax請求及處理過程詳解

    這篇文章主要介紹了Java后臺判斷ajax請求及處理過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03
  • 通過實例了解Java jdk和jre的區(qū)別

    通過實例了解Java jdk和jre的區(qū)別

    這篇文章主要介紹了通過實例了解Java jdk和jre的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • struts2通過action返回json對象

    struts2通過action返回json對象

    struts2通過action返回json對象其實很簡單的,首先我們需要引入jar包,然后在寫一個簡單的action就好了,接下來通過本文給大家介紹struts2通過action返回json對象的方法,感興趣的朋友一起看看吧
    2016-09-09
  • JAVA中IP和整數(shù)相互轉化的方法

    JAVA中IP和整數(shù)相互轉化的方法

    這篇文章主要介紹了JAVA中IP和整數(shù)相互轉化的方法,涉及java數(shù)值轉換的相關技巧,需要的朋友可以參考下
    2015-05-05

最新評論