在 Java 中对单个字符串进行排序
有没有一种原生方法可以在java中按其内容对字符串进行排序?例如:
String s = "edcba" -> "abcde"
有没有一种原生方法可以在java中按其内容对字符串进行排序?例如:
String s = "edcba" -> "abcde"
toCharArray
后跟字符串构造函数调用:Arrays.sort
import java.util.Arrays;
public class Test
{
public static void main(String[] args)
{
String original = "edcba";
char[] chars = original.toCharArray();
Arrays.sort(chars);
String sorted = new String(chars);
System.out.println(sorted);
}
}
编辑:正如 tackline 所指出的,如果字符串包含代理项对或确实复合字符(重音符号 + e 作为单独的字符)等,这将失败。在这一点上,它变得更加困难...希望你不需要这个:)此外,这只是按序数排序,而不考虑大写,重音或其他任何因素。
否,没有内置的字符串方法。您可以将其转换为 char 数组,使用 Arrays.sort 对其进行排序,然后将其转换回字符串。
String test= "edcba";
char[] ar = test.toCharArray();
Arrays.sort(ar);
String sorted = String.valueOf(ar);
或者,当您想要正确处理特定于区域设置的内容(如大写和重音字符)时:
import java.text.Collator;
import java.util.Arrays;
import java.util.Comparator;
import java.util.Locale;
public class Test
{
public static void main(String[] args)
{
Collator collator = Collator.getInstance(new Locale("fr", "FR"));
String original = "éDedCBcbAàa";
String[] split = original.split("");
Arrays.sort(split, collator);
String sorted = "";
for (int i = 0; i < split.length; i++)
{
sorted += split[i];
}
System.out.println(sorted); // "aAàbBcCdDeé"
}
}