Java实现生成n个不重复的随机数
本文实例为大家分享了Java实现生成n个不重复的随机数的具体代码,供大家参考,具体内容如下
需求:
根据min和max,生成n个不重复的随机数。(注:范围[min,max],n <= (max - min +1))
思路:
0)、把从min到max的可能出现的数字全部放进一个候选List;
1)、随机生成索引index(0 <= index <= (list.size()-1));
2)、根据index从List中取出一个数,list.get(index),并移除这个元素;
代码如下:
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
public class MyRandom {
/**
* 根据min和max随机生成一个范围在[min,max]的随机数,包括min和max
* @param min
* @param max
* @return int
*/
public int getRandom(int min, int max){
Random random = new Random();
return random.nextInt( max - min + 1 ) + min;
}
/**
* 根据min和max随机生成count个不重复的随机数组
* @param min
* @param max
* @param count
* @return int[]
*/
public int[] getRandoms(int min, int max, int count){
int[] randoms = new int[count];
List<Integer> listRandom = new ArrayList<Integer>();
if( count > ( max - min + 1 )){
return null;
}
// 将所有的可能出现的数字放进候选list
for(int i = min; i <= max; i++){
listRandom.add(i);
}
// 从候选list中取出放入数组,已经被选中的就从这个list中移除
for(int i = 0; i < count; i++){
int index = getRandom(0, listRandom.size()-1);
randoms[i] = listRandom.get(index);
listRandom.remove(index);
}
return randoms;
}
}
小编再为大家分享一段:java产生10个不同随机数的代码:
package exercise03_jdknews;
import java.util.Random;
import java.util.Vector;
/**
* 获取10个1-20之间的随机数,要求不能重复
*
* @author lgt
*
*/
public class RandomNumberNoRepeat {
public static void main(String[] args) {
//创建一个产生随机数的对象
Random r = new Random();
//创建一个存储随机数的集合
Vector<Integer> v = new Vector<Integer>();
//定义一个统计变量
int count = 0;
while(count < 10){
int number = r.nextInt(20) + 1;
//判断number是否在集合中存在
if(!v.contains(number)){
//不在集合中,就添加
v.add(number);
count++;
}
}
//遍历输出
for(int i : v){
System.out.println(i);
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
java.net.SocketException: Connection reset 解决方法
最近纠结致死的一个java报错java.net.SocketException: Connection reset 终于得到解决2013-03-03
Java集合中的CopyOnWriteArrayList使用详解
这篇文章主要介绍了Java集合中的CopyOnWriteArrayList使用详解,CopyOnWriteArrayList是ArrayList的线程安全版本,从他的名字可以推测,CopyOnWriteArrayList是在有写操作的时候会copy一份数据,然后写完再设置成新的数据,需要的朋友可以参考下2023-12-12
基于Java并发容器ConcurrentHashMap#put方法解析
下面小编就为大家带来一篇基于Java并发容器ConcurrentHashMap#put方法解析。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-06-06


最新评论