欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-06 23:10:14
核心代码 import java.util.arrays; /** * 用java产生100个1-150的数字 */ public class r...

核心代码

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