在Java中对单个String进行排序

120 java sorting string

是否有一种本地方法可以通过java中的内容对String进行排序?例如

String s = "edcba"  ->  "abcde"
Run Code Online (Sandbox Code Playgroud)

Jon*_*eet 199

toCharArray接下来是Arrays.sort一个String构造函数调用:

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);
    }
}
Run Code Online (Sandbox Code Playgroud)

编辑:正如指标所指出的那样,如果字符串包含代理对或复合字符(重音+ e作为单独的字符)等,这将失败.此时它会变得更难...希望你不需要这个:)此外,这只是按顺序排序,而不考虑大小写,重音或其他任何内容.

  • 正确的方法是对代码点进行排序.不幸的是,没有String.toCodePointArray.(我们应该排序什么顺序,顺便说一下?) (2认同)
  • 它可能不会破坏任何东西,但是如果您想考虑大写和重音符号,则排序顺序不是最佳的。该算法会将“éDedCBcbAàa”排序为“ABCDabcdeàé”,而例如在英语(美国)语言环境中,更希望获得“aAàbBcCdDeé”。 (2认同)
  • @Hengameh:您正在对字符数组进行排序,但随后忽略它。你想要 `char[] c = s.toCharArray(); 数组.sort(c); 已排序的字符串 = new String(c);` (2认同)

elj*_*nso 47

没有没有内置的String方法.您可以将其转换为char数组,使用Arrays.sort对其进行排序并将其转换回String.

String test= "edcba";
char[] ar = test.toCharArray();
Arrays.sort(ar);
String sorted = String.valueOf(ar);
Run Code Online (Sandbox Code Playgroud)

或者,当您想要正确处理特定于语言环境的内容(如大写和重音字符)时:

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é"
  }
}
Run Code Online (Sandbox Code Playgroud)

  • "我认为这样做......除非他想对包含斯瓦希里语的Strings进行排序" - 我可以看到口号 - Unicode:当你想要一种简单的本地化方法并将你的应用程序翻译成*某些*语言时.Bzzt.失败.做事*几乎*正确意味着你*几乎*没有以后修复的错误. (3认同)
  • 不知何故,我认为这会做...除非他想对包含斯瓦希里语或其他东西的字符串进行排序:) (2认同)

Mar*_*cin 29

在Java 8中,它可以通过以下方式完成:

String s = "edcba".chars()
    .sorted()
    .collect(StringBuilder::new, StringBuilder::appendCodePoint, StringBuilder::append)
    .toString();
Run Code Online (Sandbox Code Playgroud)

使用长度为1的字符串流(在未排序的字符串中的每个字符在流中转换为字符串)的稍微更短的替代方法是:

String sorted =
    Stream.of("edcba".split(""))
        .sorted()
        .collect(Collectors.joining());
Run Code Online (Sandbox Code Playgroud)


aga*_*ase 16

一种更原始​​的方法,不使用排序Arrays.sort方法.这是使用插入排序.

public static void main(String[] args){
    String wordSt="watch";
    char[] word=wordSt.toCharArray();

    for(int i=0;i<(word.length-1);i++){
        for(int j=i+1;j>0;j--){
            if(word[j]<word[j-1]){
                char temp=word[j-1];
                word[j-1]=word[j];
                word[j]=temp;
            }
        }
    }
    wordSt=String.valueOf(word);
    System.out.println(wordSt);
}
Run Code Online (Sandbox Code Playgroud)


Mar*_*oun 15

转换为字符数组排序转换回字符串:

String s = "edcba";
char[] c = s.toCharArray();        // convert to array of chars 
java.util.Arrays.sort(c);          // sort
String newString = new String(c);  // convert back to String
System.out.println(newString);     // "abcde"
Run Code Online (Sandbox Code Playgroud)

  • @NickCardoso 我真的不记得了,你问的是我在 Stack Overflow 上早期发布的答案。您真的在等待对此的解释吗? (3认同)

ami*_*mit 14

    String a ="dgfa";
    char [] c = a.toCharArray();
    Arrays.sort(c);
    return new String(c);
Run Code Online (Sandbox Code Playgroud)

请注意,如果它是一个混合大小写的字符串(它将在小写之前放置大写),这将无法按预期工作.您可以将比较器传递给Sort方法以更改它.