java中生成不重複隨機的數字
Java中產生隨機數
1 . 呼叫java.lang下面Math類中的random()方法產生隨機數
新建一個檔案字尾名為java的檔案,檔名取為MyRandom,該類中編寫如下的程式碼:
public class MyRandom {
public static void main(String[] args) {
int radom = (int)(Math.random()*10);
System.out.println(radom);
}
}
其中Math.random() //產生0~1之間的一個隨機小數。
產生一個0~9之間的整數為:(int)(Math.random()*10);
產生一個1~10之間的整數則可以寫著:(int)(Math.random()*10 + 1);
以此類推:產生一個0~n之間的數就應寫作:Math.random()*n;
取出一個指定長度大小的隨機正整數:
public static int buildRandom(int length) {
int num = 1;
double random = Math.random();
if (random < 0.1) {
random = random + 0.1;
} for (int i = 0; i < length; i++) {
num = num * 10;
}
return (int) ((random * num));
}
2 . 呼叫java.util下面Random類,此類的例項用於生成偽隨機數流,產生一個隨機整數,則呼叫該類的nextInt()方法
使用Random類之前,則在包下匯入java.util.Random ;程式碼為:
import java.util.Random;
public class MyRandom {
public static void main(String[] args) {
Random rand = new Random();
int rInt = rand.nextInt(10);
System.out.println(rInt);
}
}
其中Random rand = new Random()是建立一個新隨機數生成器;rand.nextInt(int n)是從此隨機數生成器的序列中取出的、在 0(包括)和指定值n(不包括)之間均勻分佈的 int值。
Java中在指定的整數範圍類,迴圈產生不相同的隨機數
以產生6位20以內不相同的隨即整數 為例如下:
public class MyRandom {
public static void main(String[] args) {
int n = 20;
Random rand = new Random();
boolean[] bool = new boolean[n];
int randInt = 0;
for(int i = 0; i < 6 ; i++) {
do {
randInt = rand.nextInt(n);
}while(bool[randInt]);
bool[randInt] = true;
System.out.println(randInt);
}
}
}
其中用布林變數陣列來儲存是否生成了該數字。生成後,該數字作為布林陣列下表的對應布林值變成了true,下一次生成該數字就會再次進入do...while迴圈生成數字直到產生沒有生成過的數字。
例如:生成一個int型別的陣列,長度為50的,並向其中隨即插入0-50之間的數,並且不能重複。
程式碼如下:
public class MyRandom {
public static void main(String[] args) {
int[] intRandom = new int[50];
List mylist = new ArrayList(); //生成資料集,用來儲存隨即生成數,並用於判斷
Random rd = new Random();
while(mylist.size() < 50) {
int num = rd.nextInt(51);
if(!mylist.contains(num)) {
mylist.add(num); //往集合裡面新增資料。
}
}
for(int i = 0;i <mylist.size();i++) {
intRandom[i] = (Integer)(mylist.get(i));
}
}
}
/**
* 隨機產生指定的範圍不重複的集合
* @param size
* @return
*/
public static Set<Integer> generateRandomArray(int size){
Set<Integer> set = new LinkedHashSet<Integer>(); //集合是沒有重複的值,LinkedHashSet是有順序不重複集合,HashSet則為無順序不重複集合
Integer num = size;
Integer range = size;
Random ran = new Random();
while(set.size() < num){
Integer tmp = ran.nextInt(range); //0-51之間隨機選一個數
set.add(tmp);//直接加入,當有重複值時,不會往裡加入,直到set的長度為52才結束
}
return set;
}
---------------------
作者:MrCharles
來源:CSDN
原文:https://blog.csdn.net/MrCharles/article/details/50667447
版權宣告:本文為博主原創文章,轉載請附上博文連結!