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

 更新时间:2017年02月21日 23:10:00   投稿:mdxy-dxy  
这篇文章主要介绍了用Java产生100个1-150间不重复数字,需要的朋友可以参考下

核心代码

import java.util.Arrays;

/**
 * 用Java产生100个1-150的数字
 */
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);
		}
	}

	/**
	 * 产生随机数字
	 * @param minNum 最小数字
	 * @param maxNum 最大数字
	 * @param numCount 产生的数字个数
	 * @return 结果数组
	 */
	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<count; i++) {
				
				// 同本次产生的随机数最比较
				if (num == resultArr[i]) {
					
					// 如果已存在相同的值,则跳出for循环,继续外层的while循环,产生下一个随机数
					flag = false;
					break;
				}
			}
			
			// 如果本次产生的随机数在数组中不存在,则将该随机数存放在数组中
			if (flag) {
				resultArr[count] = num;
				
				// 数组中已产生的随机数个数加1
				count++;
			}
		}
		
		return resultArr;
	}
}

代码解读

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<count; i++) {
由于每次产生的num都是随机的,所以无法保证重复的问题,所以只有通过去同已经产生的存在数组中的数字去比较,相同,则重新产生,不同,则添加进数组。

相关文章

  • Java实现二叉搜索树的插入、删除功能

    Java实现二叉搜索树的插入、删除功能

    这篇文章主要介绍了Java实现二叉搜索树的插入、删除,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • javaWeb实现简单文件上传

    javaWeb实现简单文件上传

    这篇文章主要为大家详细介绍了JAVAWeb实现简单文件上传,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • Java项目中获取路径的绝对路径问题和相对路径问题

    Java项目中获取路径的绝对路径问题和相对路径问题

    这篇文章主要介绍了如何Java项目中获取文件地址,在 Java 项目中我们经常会读取配置文件,但是文件的路径在获取时我们是怎么得到的?下面我们就一起进入文章学习该内容吧,需要的朋友可以参考下
    2022-02-02
  • java实现遍历树形菜单两种实现代码分享

    java实现遍历树形菜单两种实现代码分享

    这篇文章主要介绍了java实现遍历树形菜单两种实现代码分享,两种实现:OpenSessionView实现、TreeAction实现。具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • 浅谈Java中的可变参数

    浅谈Java中的可变参数

    下面小编就为大家带来一篇浅谈Java中的可变参数。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • Java读取resources中资源文件路径以及jar中文件无法读取的解决

    Java读取resources中资源文件路径以及jar中文件无法读取的解决

    这篇文章主要介绍了Java读取resources中资源文件路径以及jar中文件无法读取的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • 如何使用拦截器获取请求的入参并将其转化为Java对象详解

    如何使用拦截器获取请求的入参并将其转化为Java对象详解

    这篇文章主要介绍了如何使用拦截器获取请求的入参并将其转化为Java对象的相关资料,文中介绍了两种实现的方法,并给出了详细的代码示例,需要的朋友可以参考下
    2025-02-02
  • Java语言实现对MySql数据库中数据的增删改查操作的代码

    Java语言实现对MySql数据库中数据的增删改查操作的代码

    这篇文章主要介绍了Java语言实现对MySql数据库中数据的增删改查操作的代码,实现了连接数据库,和数据库的增删改查操作,有兴趣的可以了解一下。
    2016-12-12
  • 拉钩网java笔试题分享

    拉钩网java笔试题分享

    这篇文章主要介绍了拉钩网java笔试题分享,下面是题目和实现示例,需要的朋友可以参考下
    2014-05-05
  • Java自定义Enum的实现示例

    Java自定义Enum的实现示例

    Java中的自定义Enum类型是一种特殊的类,用于表示固定数量的常量值,本文主要介绍了Java自定义Enum的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12

最新评论