Java产生100个1-150间不重复数字
发布时间:2020-05-28 21:11:35 所属栏目:Java 来源:互联网
导读:Java产生100个1-150间不重复数字
|
下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。 脚本之家小编现在分享给大家,也给大家做个参考。 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;
}
}
由于每次产生的num都是随机的,所以无法保证重复的问题,所以只有通过去同已经产生的存在数组中的数字去比较,相同,则重新产生,不同,则添加进数组。 以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。 如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
