摘要:使用單個種子創(chuàng)建一個新的隨機(jī)數(shù)生成器。如下面的代碼初始化時并沒有起直接作用注意不是沒有起作用中的是隨機(jī)數(shù)的上限產(chǎn)生的隨機(jī)數(shù)為的整數(shù)不包括。返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的均勻分布的值。
一個問題
這個題是阿里2015實習(xí)生筆試的一道附加題
package gsm; import java.util.ArrayList; import java.util.List; import java.util.Random; public class Test2 { public static void main(String[] args) { Listlist = new ArrayList (); for (int i = 1; i <= 1000; i++) { list.add(i); } for (int j = 0; j < 900; j++) { getValue(list); } } //生成隨機(jī)數(shù) public static void getValue(List list) { Random randomGenerator = new Random(); int a = randomGenerator.nextInt(list.size()); int value = list.get(a); System.out.println(value + ""); // 這個數(shù)已經(jīng)出現(xiàn)過了,那么從list中刪除 list.remove(a); } }
以下內(nèi)容為轉(zhuǎn)載:via 喜歡天才的博客
今天在做 Java 練習(xí)的時候注意到了 Java 里面的一個隨機(jī)函數(shù)——Random,剛開始只是知道這個函數(shù)具有隨機(jī)取值的作用,于是上網(wǎng)搜索了資料一番,做了一下一些關(guān)于 Random 函數(shù)的總結(jié):
Java 中存在著兩種 Random 函數(shù):
1. java.lang.Math.Random;調(diào)用這個 Math.Random() 函數(shù)能夠返回帶正號的 double 值,該值大于等于 0.0 且小于 1.0,即取值范圍是 [0.0,1.0) 的左閉右開區(qū)間,返回值是一個偽隨機(jī)選擇的數(shù),在該范圍內(nèi)(近似)均勻分布。
例如下面的實驗代碼
編譯通過后運(yùn)行結(jié)果如下圖
觀察會發(fā)現(xiàn)代碼的用一個循環(huán) 10 次循環(huán)輸出 num 的取值,均隨機(jī)分布在 [0,3) 之間!在使用 Math.Random() 的時候需要注意的地方時該函數(shù)是返回 double 類型的值,所以在要賦值給其他類型的變量的時候注意需要進(jìn)行塑形轉(zhuǎn)換。
2. java.util.Random;在 Java 的 API 幫助文檔中,總結(jié)了一下對這個 Random() 函數(shù)功能的描述:
java.util.Random 類中實現(xiàn)的隨機(jī)算法是偽隨機(jī),也就是有規(guī)則的隨機(jī),所謂有規(guī)則的就是在給定種 子(seed) 的區(qū)間內(nèi)隨機(jī)生成數(shù)字;
相同種子數(shù)的 Random 對象,相同次數(shù)生成的隨機(jī)數(shù)字是完全相同的;
Random 類中各方法生成的隨機(jī)數(shù)字都是均勻分布的,也就是說區(qū)間內(nèi)部的數(shù)字生成的幾率均等;
下面 Random() 的兩種構(gòu)造方法
Random():創(chuàng)建一個新的隨機(jī)數(shù)生成器。
Random(long seed):使用單個 long 種子創(chuàng)建一個新的隨機(jī)數(shù)生成器。
我們可以在構(gòu)造 Random 對象的時候指定種子(這里指定種子有何作用,請接著往下看),如:
Random r1 = new Random(20);
或者默認(rèn)當(dāng)前系統(tǒng)時間對應(yīng)的相對時間有關(guān)的數(shù)字作為種子數(shù):
Random r1 = new Random();
需要說明的是:你在創(chuàng)建一個 Random 對象的時候可以給定任意一個合法的種子數(shù),種子數(shù)只是隨機(jī)算法的起源數(shù)字,和生成的隨機(jī)數(shù)的區(qū)間沒有任何關(guān)系。如下面的 Java 代碼:
Random rand =new Random(25); int i; i=rand.nextInt(100);
初始化時 25 并沒有起直接作用(注意:不是沒有起作用),rand.nextInt(100); 中的 100 是隨機(jī)數(shù)的上限, 產(chǎn)生的隨機(jī)數(shù)為 0-100 的整數(shù), 不包括 100。
下面是 Java.util.Random() 方法摘要
protected int next(int bits):生成下一個偽隨機(jī)數(shù)。
boolean nextBoolean():返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的均勻分布的 boolean 值。
void nextBytes(byte[] bytes):生成隨機(jī)字節(jié)并將其置于用戶提供的 byte 數(shù)組中。
double nextDouble():返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的、在 0.0 和 1.0 之間均勻分布的 double 值。
float nextFloat():返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的、在 0.0 和 1.0 之間均勻分布 float 值。
double nextGaussian():返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的、呈高斯(“正態(tài)”)分布的 double 值,其平均值是 0.0 標(biāo)準(zhǔn)差是 1.0。
int nextInt():返回下一個偽隨機(jī)數(shù),它是此隨機(jī)數(shù)生成器的序列中均勻分布的 int 值。
int nextInt(int n):返回一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的、在(包括和指定值(不包括)之間均勻分布的 int 值。
long nextLong():返回下一個偽隨機(jī)數(shù),它是取自此隨機(jī)數(shù)生成器序列的均勻分布的 long 值。
void setSeed(long seed):使用單個 long 種子設(shè)置此隨機(jī)數(shù)生成器的種子。
方法摘要也就這些,下面給幾個例子:
生成 [0,1.0) 區(qū)間的小數(shù):double d1 = r.nextDouble();
生成 [0,5.0) 區(qū)間的小數(shù):double d2 = r.nextDouble() * 5;
生成 [1,2.5) 區(qū)間的小數(shù):double d3 = r.nextDouble() * 1.5 + 1;
生成 -231 到 231-1 之間的整數(shù):int n = r.nextInt();
生成 [0,10) 區(qū)間的整數(shù):
int n2 = r.nextInt(10);// 方法一 n2 = Math.abs(r.nextInt() % 10);// 方法二
前面曾講到過構(gòu)造 Random 對象的時候指定種子的問題,到底指定種子有什么作用呢,這里直接用代碼例子來做說明:
在定義的時候分別指定了相同的種子之后,在分別用 r1 和 r2 去 [0,30) 的隨機(jī)數(shù),結(jié)果編譯執(zhí)行后悔發(fā)現(xiàn)結(jié)果都是呈現(xiàn) AABB 型的,說明 r1 和 r2 取的隨機(jī)數(shù)是一模一樣的(下圖為實驗截圖)。
如果我改動代碼,改成下面這樣:
再編譯輸出后,就再也不會得到 AABB 型的結(jié)果,根據(jù)代碼的區(qū)別,就可以知道指定種子數(shù),和不指定種子數(shù)的區(qū)別在于哪里了。
最后再來簡單對比一下這兩個隨機(jī)函數(shù)到底的特點:
java.Math.Random() 實際是在內(nèi)部調(diào)用 java.util.Random() 的, 它有一個致命的弱點,它和系統(tǒng)時間有關(guān),也就是說相隔時間很短的兩個 random 比如:
double a = Math.random(); double b = Math.random();
即有可能會得到兩個一模一樣的 double。
java.util.Random() 在調(diào)用的時候可以實現(xiàn)和 java.Math.Random() 一樣的功能,而且他具有很多的調(diào)用方法,相對來說比較靈活。所以從總體來看,使用 java.util.Random() 會相對來說比較靈活一些。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/64297.html
摘要:加密算法筆記算法實現(xiàn)在使用中發(fā)現(xiàn),經(jīng)過加密的字符串如果要進(jìn)行傳輸,需要使用進(jìn)行編碼,這樣能保證加密信息的完整性,確保將來解密成功。 Java加密算法筆記--DES算法實現(xiàn) 在使用中發(fā)現(xiàn),經(jīng)過加密的字符串如果要進(jìn)行傳輸,需要使用Base64進(jìn)行編碼,這樣能保證加密信息的完整性,確保將來解密成功。 import java.security.SecureRandom; import java...
摘要:構(gòu)造器的參數(shù)沒有確切地描述其返回的對象,適當(dāng)名稱的靜態(tài)工廠方法更容易使用,也易于閱讀。在文檔中,沒有像構(gòu)造器那樣明確標(biāo)識出來,因此,對于提供了靜態(tài)工廠方法而不是構(gòu)造器的類來說,要查明如何實例化一個類,有點困難。 第二章 創(chuàng)建和銷毀對象 第1條 考慮用靜態(tài)工廠方法代替構(gòu)造器 兩者創(chuàng)建對象的形式,例如:構(gòu)造器是new Boolean();靜態(tài)工廠方法是 public static Bool...
摘要:并返回合理錯誤提示。如果不在則再輸入密碼,成功則增加用戶信息到文件中,密碼進(jìn)行加密處理。作業(yè)增加用戶名,密碼的合法化判斷和錯誤提示。 課時5:字符串-基礎(chǔ) 切片,索引 s = use python do somenthing s[1],s[-1],s[1:3],s[1:6:2],s[1:],s[:-1],s[:] spilt,join,[start:stop:step] 常用方法集...
摘要:是一個基于和概念的項目自動化構(gòu)建工具。當(dāng)前其支持的語言限于和主要面向應(yīng)用。本次分享將具體講述如何利用來創(chuàng)建一個簡單的項目。首先我們新建一個文件夾作為展示的項目。中的代碼如下這是用來定義項目。接著創(chuàng)建文件夾,這是項目開發(fā)中習(xí)慣性的構(gòu)建方法。 ??Gradle是一個基于Apache Ant和Apache Maven概念的項目自動化構(gòu)建工具。它使用一種基于Groovy的特定領(lǐng)域語言(DSL)...
摘要:注該筆記適合有基礎(chǔ)或者有復(fù)習(xí)需求的小伙伴哦預(yù)習(xí)的話建議直接看視頻俺舅是鏈接邀請碼太過簡單的知識點都被作者扔到回收站了所以這些知識點都是精華呦一快捷鍵與常見問題運(yùn)行當(dāng)前程序其它運(yùn)行方法右鍵小蟲子圖像右邊的圖標(biāo)運(yùn)行錯誤運(yùn)行 ...
閱讀 2380·2021-11-22 14:56
閱讀 1188·2019-08-30 15:55
閱讀 3218·2019-08-29 13:29
閱讀 1368·2019-08-26 13:56
閱讀 3517·2019-08-26 13:37
閱讀 573·2019-08-26 13:33
閱讀 3359·2019-08-26 13:33
閱讀 2242·2019-08-26 13:33