package com.Annual.util;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.Random;
import java.util.Set;
public
class AnnualUtil {
/**
* 产生 0 到 max 的随机数
* @param max
* @return
*/
public static int random(int max) {
Random random = new Random();
return random.nextInt(max);
}
/**
* 产生 min 到 max 的随机数 min不能为0
* @param min
* @param max
* @return
*/
public static int random(int min, int max) {
Random random = new Random();
return random.nextInt(max) % (max - min + 1) + min;
}
/**
* 生成drawPeople个不同的随机数,且随机数区间为[0,numPeople)
* @param n
* @return
*/
public static Set<Integer> getDiffSetNO(int drawPeople , int numPeople){
Set<Integer> randomSet = new HashSet<>();
//随机生成drawPeople个随机数
//用set加死
循环保证生成 {drawPeople} 个不重复的随机数
while (true) {
randomSet.add(new Random().nextInt(numPeople));
if(randomSet.size() >= drawPeople){
break;
}
}
return randomSet;
}
/**
* 生成n个不同的随机数,且随机数区间为[0,10)
* @param n
* @return
*/
public static ArrayList getDiffNO(int n){
// 生成 [0-n) 个不重复的随机数
// list 用来保存这些随机数
ArrayList list = new ArrayList();
Random rand = new Random();
boolean[] bool = new boolean[n];
int num = 0;
for (int i = 0; i < n; i++) {
do {
// 如果产生的数相同继续循环
num = rand.nextInt(n);
} while (bool[num]);
bool[num] = true;
list.add(num);
}
return list;
}
public static void main(String[] args){
System.out.println(AnnualUtil.random(4));
System.out.println(AnnualUtil.random(3,4));
Random ran1 = new Random(11);
System.out.println("使用
种子为10的Random对象生成[0,10)内随机整数序列: ");
for (int i = 0; i < 10; i++) {
System.out.print(ran1.nextInt(1000) + " ");
}
System.out.println();
Random ran2 = new Random(11);
System.out.println("使用另一个种子为10的Random对象生成[0,10)内随机整数序列: ");
for (int i = 0; i < 10; i++) {
System.out.print(ran2.nextInt(1000) + " ");
}
// 另外,直接使用Random无法避免生成重复的数字,如果需要生成不重复的随机数序列,需要借助数组和
集合类
ArrayList list=AnnualUtil.getDiffNO(20);
System.out.println();
System.out.println("产生的n个不同的随机数getDiffNO:"+list);
Set<Integer> randomSet = AnnualUtil.getDiffSetNO(20, 100);
System.out.println();
System.out.println("产生的n个不同的随机数getDiffSetNO:"+randomSet);
}
}