Java生成可重复的随机数
时间: 2023-07-29 14:05:56 浏览: 103
在Java中,可以使用`java.util.Random`类来生成随机数。如果需要生成可重复的随机数,可以使用相同的种子(seed)来初始化`Random`对象。
以下是一个简单的示例代码:
```java
import java.util.Random;
public class RandomExample {
public static void main(String[] args) {
Random random = new Random(123); // 使用种子为123初始化Random对象
int randomNumber1 = random.nextInt(100); // 生成一个0-99的随机整数
int randomNumber2 = random.nextInt(100); // 生成另一个0-99的随机整数
System.out.println("Random Number 1: " + randomNumber1);
System.out.println("Random Number 2: " + randomNumber2);
}
}
```
在上面的示例代码中,我们使用种子为123初始化`Random`对象,然后使用`nextInt(int n)`方法生成0-99之间的随机整数。由于我们使用相同的种子来初始化`Random`对象,因此每次运行程序时都会得到相同的随机数序列,从而实现了可重复的随机数生成。
相关问题
java生成永远不重复的随机数_java生成不重复随机数的方法
生成不重复的随机数可以采用以下两种方法:
1. 使用java.util.Random类生成随机数,并将生成的随机数存储到一个Set或者List容器中,每次生成新的随机数时都先检查容器中是否已经存在该随机数,如果已存在则重新生成,直到生成一个不在容器中的随机数。
示例代码:
```java
import java.util.HashSet;
import java.util.Random;
import java.util.Set;
public class RandomUtil {
private static Set<Integer> set = new HashSet<>();
private static Random random = new Random();
private static final int MAX_NUM = 100;
public static int generateRandom() {
int randomNum;
do {
randomNum = random.nextInt(MAX_NUM);
} while (set.contains(randomNum));
set.add(randomNum);
return randomNum;
}
}
```
2. 使用java.security.SecureRandom类生成随机数,并将生成的随机数存储到一个数组中,每次生成新的随机数时,从数组中随机取出一个数,并将该位置上的数与数组末尾的数交换位置,然后缩小数组范围,以避免重复。
示例代码:
```java
import java.security.SecureRandom;
public class RandomUtil {
private static final int MAX_NUM = 100;
private static int[] arr = new int[MAX_NUM];
private static SecureRandom secureRandom = new SecureRandom();
private static int size = MAX_NUM;
static {
for (int i = 0; i < MAX_NUM; i++) {
arr[i] = i;
}
}
public static int generateRandom() {
if (size == 0) {
size = MAX_NUM;
}
int index = secureRandom.nextInt(size--);
int randomNum = arr[index];
arr[index] = arr[size];
arr[size] = randomNum;
return randomNum;
}
}
```
以上两种方法都可以生成不重复的随机数,但是第二种方法使用了安全的随机数生成器,更加安全可靠。
java生成不重复随机数
可以使用Java中的Random类来生成随机数,通过判断每次生成的随机数是否已经存在,来确保生成的随机数不重复。以下是一个示例代码:
```java
import java.util.Random;
import java.util.HashSet;
public class UniqueRandomNumberGenerator {
public static void main(String[] args) {
int min = 1;
int max = 10;
int count = 5;
Random random = new Random();
HashSet<Integer> set = new HashSet<Integer>();
while (set.size() < count) {
int randomNumber = random.nextInt(max - min + 1) + min;
set.add(randomNumber);
}
for (int number : set) {
System.out.print(number + " ");
}
}
}
```
在上面的代码中,我们使用了一个HashSet来存储生成的随机数,因为HashSet不允许重复元素,所以我们可以通过判断HashSet的大小是否达到了指定的个数来判断是否已经生成了足够的不重复随机数。
阅读全文