Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解
Java 生成隨機(jī)字符串?dāng)?shù)組的實(shí)例詳解
利用Collections.sort()方法對(duì)泛型為String的List 進(jìn)行排序。具體要求:
1.創(chuàng)建完List<String>之后,往其中添加十條隨機(jī)字符串
2.每條字符串的長(zhǎng)度為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í)過(guò)程中一個(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 對(duì)象,利用其中的 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. 生成一條長(zhǎng)度為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(); //確定字符串長(zhǎng)度 int stringLength = (int) (Math.random()*10);
2.2 現(xiàn)在字符串的長(zhǎng)度可以確認(rèn),也實(shí)現(xiàn)了生成隨機(jī)的字符,再利用 for 循環(huán)就可以生成一條長(zhǎng)度為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)過(guò)上述的兩個(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 最后對(duì)集合排序
5.1 調(diào)用 Collections.sort() 方法對(duì)集合排序,其排序的規(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條長(zhǎng)度為1-10的隨機(jī)字符串
for (int i = 0; i < 10; i++) {
StringBuffer stringBuffer = new StringBuffer();
//確定字符串長(zhǎng)度
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í)例詳解,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- java實(shí)現(xiàn)6種字符串?dāng)?shù)組的排序(String array sort)
- 淺談java中字符串?dāng)?shù)組、字符串、整形之間的轉(zhuǎn)換
- java String[]字符串?dāng)?shù)組自動(dòng)排序的簡(jiǎn)單實(shí)現(xiàn)
- java字符串?dāng)?shù)組進(jìn)行大小排序的簡(jiǎ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)之二叉搜索樹(shù)詳解
二叉搜索樹(shù)作為一個(gè)經(jīng)典的數(shù)據(jù)結(jié)構(gòu),具有鏈表的快速插入與刪除的特點(diǎn),同時(shí)查詢效率也很優(yōu)秀,所以應(yīng)用十分廣泛。本文將詳細(xì)講講二叉搜索樹(shù)的原理與實(shí)現(xiàn),需要的可以參考一下2022-06-06
Spring Boot 單元測(cè)試JUnit的實(shí)踐
JUnit是一款優(yōu)秀的開(kāi)源Java單元測(cè)試框架,也是目前使用率最高最流行的測(cè)試框架,這篇文章主要介紹了Spring Boot 單元測(cè)試JUnit的實(shí)踐,感興趣的小伙伴們可以參考一下2018-11-11
使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者
這篇文章主要介紹了使用spring boot 整合kafka,延遲啟動(dòng)消費(fèi)者的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例
Java:DocumentBuilderFactory調(diào)用XML的方法實(shí)例,需要的朋友可以參考一下2013-04-04
Java-文件File簡(jiǎn)單實(shí)用方法(分享)
下面小編就為大家?guī)?lái)一篇Java-文件File簡(jiǎn)單實(shí)用方法(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08

