栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

用Java产生100个1-150间不重复数字

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用Java产生100个1-150间不重复数字

核心代码

import java.util.Arrays;


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("+++++++++++++++++===================+++++++++++++");
		
		// 对结果数组排序后再输出
		Arrays.sort(resultArr);
		for (Integer num : resultArr) {
			System.out.println(num);
		}
	}

	
	public static int[] produceNum(int minNum, int maxNum, int numCount) {
		
		// 入参校验
		// 如果随机数的个数大于产生随机数的范围;或最大数小于最小数
		// 直接返回null,说明入参不符合要求
		if (numCount > (maxNum - minNum + 1) || maxNum < minNum) {
			return null;
		}
		
		// 存放结果的数组
		int[] resultArr = new int[numCount];
		
		// count 记录已产生的随机数的个数
		int count = 0;
		
		while(count < numCount) {
			
			// 产生随机数
			int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
			
			// flag 定义本次产生的随机数是否已在数组中
			boolean flag = true;
			
			// 遍历数组中已产生的随机数
			for (int i=0; i

代码解读

1 int num = (int) (Math.random() * (maxNum - minNum)) + minNum;
Math.random() 产生的是0~1 之间的double类型的随机数
Math.random() * 10 便会得到 0 ~ 10 之间的随机数,转int后便是0 ~ 9;如果给 Math.random() * 10 + 1,便是1 ~ 11 之间的随机数,转int便是1 ~ 10。
这里的1 相当于程序中的最小值,11则为最大值。
这样便得到了产生随机数的 (int) (Math.random() * (maxNum - minNum)) + minNum

2 for (int i=0; i 由于每次产生的num都是随机的,所以无法保证重复的问题,所以只有通过去同已经产生的存在数组中的数字去比较,相同,则重新产生,不同,则添加进数组。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/147556.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号