代碼如下:
package net.dc.algchallenge;
import java.util.Arrays;
import java.util.Scanner;
public class StrSort {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);//引入輸入的功能
String totalStr = "";//因不能使用列表等可變長度集合,所以定義該字符串用於裝循環中輸入的字符串,再使用split方法拆分,變相達到數組長度可變
System.out.println("請輸入字符串,輸入exit結束");
while (true) {
//輸入部分
System.out.print("請輸入:");
String str = sc.next();
//處理部分
if (str.equals("exit")) {//輸入的字符串是exit,就將totalStr拆分並進行排序處理
String[] strArr = totalStr.split(";");//以';'爲分隔符,將字符串分割
//取出字符串的第一個字符並使用選擇排序進行排序處理
for (int i = 0; i < strArr.length - 1; i++) {
for (int j = i + 1; j < strArr.length; j++) {
if (strArr[i].charAt(0) > strArr[j].charAt(0)) {
String tempStr = strArr[i];
strArr[i] = strArr[j];
strArr[j] = tempStr;
}
}
}
System.out.println("排序後:");
//使用lambda表達式輸出,比較簡潔
Arrays.asList(strArr).forEach(System.out::println);
break;
} else {
//如果輸入的字符串不是exit,就在其後添加';'(方便後續的拆分),並將其添加在totalStr末尾
String str1 = String.format("%s;", str);
totalStr = totalStr.concat(str1);
}
}
}
}
實現效果: