gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章用Java产生100个1-150间不重复数字由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

核心代码 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
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产生100个1-150间不重复数字的文章就讲到这里了,如果你想了解更多关于用Java产生100个1-150间不重复数字的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com