Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解
Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解
利用Collections.sort()方法對泛型為String的List 進(jìn)行排序。具體要求:
1.創(chuàng)建完List<String>之后,往其中添加十條隨機(jī)字符串
2.每條字符串的長度為10以內(nèi)的隨機(jī)整數(shù)
3.每條字符串的每個(gè)字符都為隨機(jī)生成的字符,字符可以重疊
4.每條隨機(jī)字符串不可重復(fù)
將涉及到的知識(shí)有: String、StringBuffer、ListArray、泛型、Collections.sort、foreach、Random等相關(guān)知識(shí),算是 在JAVA 學(xué)習(xí)過程中一個(gè)比較好的的實(shí)踐。
1. 隨機(jī)生成一個(gè)字符
1.1 先將所有的字母和0-9的數(shù)字存放于一個(gè)字符串中,以便后續(xù)使用。
String str = "aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStT uUvVwWxXyYzZ0123456789";
1.2 因?yàn)橐獫M足隨機(jī)性,所以創(chuàng)建一個(gè) Random 對象,利用其中的 nextInt(str.length) 方法生成一個(gè) 0 — str.length 的隨機(jī)數(shù)。
Random random = new Random(); int index = random.nextInt(str.length());
1.3 再將上述生成的隨機(jī)數(shù)作為 str 字符串的索引取出相應(yīng)的字符,及隨機(jī)生成了一個(gè)字符
char c = str.charAt(index);
2. 生成一條長度為10以內(nèi)的隨機(jī)字符串
2.1 因?yàn)槭?0以內(nèi)且滿足隨機(jī)性,所以此處使用 Math.random() 函數(shù),其返回值為隨機(jī) 0.0 - 1.0 的 Double 類型的數(shù)
StringBuffer stringBuffer = new StringBuffer(); //確定字符串長度 int stringLength = (int) (Math.random()*10);
2.2 現(xiàn)在字符串的長度可以確認(rèn),也實(shí)現(xiàn)了生成隨機(jī)的字符,再利用 for 循環(huán)就可以生成一條長度為10以內(nèi)的隨機(jī)字符串
for (int j = 0; j < stringLength; j++) { int index = random.nextInt(str.length()); char c = str.charAt(index); stringBuffer.append(c); } //將StringBuffer轉(zhuǎn)換為String類型的字符串 String string = stringBuffer.toString();
3. 生成10條隨機(jī)字符串
3.1 經(jīng)過上述的兩個(gè)步驟,再在外部嵌套一個(gè) for 循環(huán)就可以生成 10 條隨機(jī)字符串
4. 創(chuàng)建一個(gè) ListArray<String> 集合儲(chǔ)存著10條隨機(jī)字符串
4.1 創(chuàng)建一個(gè) String 類型集合,該步奏應(yīng)該和步奏3同步完成
List<String> listString = new ArrayList<String>();
4.2 將每次生成的一條字符串添加到集合中,注意利用集合的 Contains() 方法判斷集合中之前是否已存在相同的字符串(雖然概率很小)。
//判斷當(dāng)前的list容器中是否已有剛生成的字符串,滿足每條字符串不可重復(fù)性 if(!(listString.contains(stringBuffer.toString()))){ listString.add(stringBuffer.toString()); }else { //i-- 如果不滿足則重新生成 i--; }
5 最后對集合排序
5.1 調(diào)用 Collections.sort() 方法對集合排序,其排序的規(guī)則如下:
- 從左向右原則,且0-9
- 數(shù)字優(yōu)先原則,且A-Z
- 字母大寫優(yōu)先原則,且a-z
總的代碼
import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.List; import java.util.Random; public class RandomString { public static void main(String[] args) { List<String> strList = randomString(); System.out.println("------隨機(jī)生成的10條字符串-------"); for (String string : strList) { System.out.println(string); } System.out.println("------------排序后------------"); Collections.sort(strList); for (String string : strList) { System.out.println(string); } } public static List<String> randomString(){ //將所有的大小寫字母和0-9數(shù)字存入字符串中 String str = "aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ0123456789"; Random random = new Random(); List<String> listString = new ArrayList<String>(); String strArray[ ] = new String[10]; //生成10條長度為1-10的隨機(jī)字符串 for (int i = 0; i < 10; i++) { StringBuffer stringBuffer = new StringBuffer(); //確定字符串長度 int stringLength = (int) (Math.random()*10); for (int j = 0; j < stringLength; j++) { //先隨機(jī)生成初始定義的字符串 str 的某個(gè)索引,以獲取相應(yīng)的字符 int index = random.nextInt(str.length()); char c = str.charAt(index); stringBuffer.append(c); } //判斷當(dāng)前的list容器中是否已有剛生成的字符串,滿足每條字符串不可重復(fù)性 if (!(listString.contains(stringBuffer.toString()))) { listString.add(stringBuffer.toString()); }else { i--; } } return listString; } }
輸出答案不唯一
以上就是Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解,如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- java實(shí)現(xiàn)6種字符串?dāng)?shù)組的排序(String array sort)
- 淺談java中字符串?dāng)?shù)組、字符串、整形之間的轉(zhuǎn)換
- java String[]字符串?dāng)?shù)組自動(dòng)排序的簡單實(shí)現(xiàn)
- java字符串?dāng)?shù)組進(jìn)行大小排序的簡單實(shí)現(xiàn)
- Java編程實(shí)現(xiàn)中英混合字符串?dāng)?shù)組按首字母排序的方法
- JAVA中字符串如何與整型數(shù)字相加
- JAVA中整型數(shù)組、字符串?dāng)?shù)組、整型數(shù)和字符串 的創(chuàng)建與轉(zhuǎn)換的方法
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)之二叉搜索樹詳解
二叉搜索樹作為一個(gè)經(jīng)典的數(shù)據(jù)結(jié)構(gòu),具有鏈表的快速插入與刪除的特點(diǎn),同時(shí)查詢效率也很優(yōu)秀,所以應(yīng)用十分廣泛。本文將詳細(xì)講講二叉搜索樹的原理與實(shí)現(xiàn),需要的可以參考一下2022-06-06使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者
這篇文章主要介紹了使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者的操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例
Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例,需要的朋友可以參考一下2013-04-04