java中判断随机数是否相同_java中怎样让随机数不重复

java中要使生成的随机数不重复可以将已经生成的随机数放入到数组中,每次生成随机数时与数组的内容比较是否相等,相等则重新生成,不相等则存入数组。示例代码如下(生成10之内的4个不相等的整数):public class Demo {    public static void main(String[] args) {        int[] a = new int[]{-1,-1,-1,-1};//初始化数组        Random random = new Random();        int count = 0;//记录有效的随机数个数        while(count < a.length){            boolean flag = true;//用来标志的变量            int r = random.nextInt(10);            for(int i=0;i<a.length;i++){                if(r == a[i]){                    flag = false;                    break;                }            }            if(flag){                a[count] = r;                System.out.println(r);                count++;            }        }    }}其中的变量flag用来标志产生的随机数是否已经存在,默认值设置为true,表示不存在,flase表示该随机数已经存在。

阅读全文 >

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用java.util.Random类的nextInt(int n)方法,其的参数n表示随机数的范围,然后定义一个Set集合,将生成的随机数放入Set集合,如果Set集合已经存在该随机数,则重新生成,直到生成的随机数不存在Set集合为止。 ### 回答2: 在Java,要生成不重复随机数,可以使用Set集合来实现。 首先,我们需要导入java.util.Set和java.util.Random类。然后,我们可以创建一个Set集合,并使用Random类生成随机数。 接下来,我们可以使用while循环来不断生成新的随机数,直到生成的随机数不在Set集合存在为止。然后,将这个随机数添加到Set集合。 最后,我们可以将Set集合的元素转换为数组,以便于我们进一步使用。 下面是一个示例代码: ```java import java.util.HashSet; import java.util.Random; import java.util.Set; public class UniqueRandomNumberGenerator { public static void main(String[] args) { Set<Integer> uniqueNumbers = new HashSet<>(); Random random = new Random(); while (uniqueNumbers.size() < 10) { int randomNumber = random.nextInt(100); // 生成0到99之间的随机数 if (!uniqueNumbers.contains(randomNumber)) { uniqueNumbers.add(randomNumber); } } int[] uniqueNumberArray = new int[uniqueNumbers.size()]; int index = 0; for (int number : uniqueNumbers) { uniqueNumberArray[index++] = number; } for (int number : uniqueNumberArray) { System.out.println(number); } } } ``` 上述代码,使用HashSet来存储随机数,因为HashSet不允许重复元素。当生成的随机数不在Set集合存在时,才将其添加到Set集合。 最后,将Set集合的元素转换为数组,便于我们进一步使用。在示例,我们列举了其10个不重复随机数,并输出到控制台上。 希望对你有所帮助! ### 回答3: 在Java,要实现生成不重复随机数,可以借助Java集合框架的HashSet或LinkedHashSet来实现。以下是一种可能的实现方式: 1. 创建一个HashSet或LinkedHashSet来存储随机数。 2. 利用Java的Random类生成随机数。 3. 使用while循环,反复生成随机数判断是否已存在于集合。 4. 如果不存在,则将该随机数添加到集合。 5. 当集合大小达到所需的随机数个数时,退出循环。 6. 最后,通过迭代器或转换为数组等方式获取到这些不重复随机数。 以下是示例代码: ```java import java.util.HashSet; import java.util.Random; import java.util.Set; public class RandomNumbers { public static void main(String[] args) { Set<Integer> randomNumbers = new HashSet<>(); // 或者使用LinkedHashSet Random random = new Random(); while (randomNumbers.size() < 10) { // 设置所需的随机数个数 int randomNumber = random.nextInt(100); // 生成0-99之间的随机数 if (!randomNumbers.contains(randomNumber)) { randomNumbers.add(randomNumber); } } for (int number : randomNumbers) { System.out.print(number + " "); } } } ``` 以上代码将生成10个不重复随机数,并输出到控制台。你可以根据需要修改所需的随机数个数,并进行相应的处理。请注意,这种方法适用于生成较小范围内的不重复随机数,如果所需的范围较大或数量较多,可能需要使用其他更复杂的算法或数据结构来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值