Java实现字符串排序
程序员文章站
2024-03-17 08:34:58
...
代码如下:
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);
}
}
}
}
实现效果: