最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
用Java产生100个1-150间不重复数字
时间:2022-06-29 01:38:30 编辑:袖梨 来源:一聚教程网
核心代码
代码如下 | 复制代码 |
importjava.util.Arrays;
/** * 用Java产生100个1-150的数字 */ publicclassRandomTest {
publicstaticvoidmain(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 结果数组 */ publicstaticint[] produceNum(intminNum,intmaxNum,intnumCount) {
// 入参校验 // 如果随机数的个数大于产生随机数的范围;或最大数小于最小数 // 直接返回null,说明入参不符合要求 if(numCount > (maxNum - minNum +1) || maxNum < minNum) { returnnull; }
// 存放结果的数组 int[] resultArr =newint[numCount];
// count 记录已产生的随机数的个数 intcount =0;
while(count < numCount) {
// 产生随机数 intnum = (int) (Math.random() * (maxNum - minNum)) + minNum;
// flag 定义本次产生的随机数是否已在数组中 booleanflag =true;
// 遍历数组中已产生的随机数 for(inti=0; i // 同本次产生的随机数最比较 if(num == resultArr[i]) { // 如果已存在相同的值,则跳出for循环,继续外层的while循环,产生下一个随机数 flag =false; break; } } // 如果本次产生的随机数在数组中不存在,则将该随机数存放在数组中 if(flag) { resultArr[count] = num; // 数组中已产生的随机数个数加1 count++; } } returnresultArr; } } |
代码解读
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
相关文章
- 《燕云十六声》配置要求介绍 12-25
- 《燕云十六声》搬砖介绍 12-25
- 时空中的绘旅人天宇之间怎么玩 绘旅人天宇之间活动玩法介绍 12-25
- QQ2024年度报告怎么看 2024qq年度报告玩法介绍 12-25
- 归龙潮珠砂什么时候up 归龙潮红缘绮梦卡池介绍 12-25
- 王者荣耀S38赛季有什么更新 12-25