Java中按字母顺序对字符串进行排序

培训教学 潘老师 8个月前 (09-13) 434 ℃ (0) 扫码查看

本 Java 教程讨论按字母顺序对字符串进行排序的不同方法。按字母顺序排序时,我们本质上是按字母顺序对字符串的字符进行排序。

1. 使用 Java 8 Streams 对字符串进行排序

Stream.sorted ()方法按自然顺序对流元素进行排序。对于字符串,自然顺序是字母顺序。所以我们需要执行以下伪步骤:

  • 从字符串创建字符流
  • 对流进行排序
  • 加入 Stream 以获取新的排序字符串

以下 Java 程序演示了使用 API 对字符串的字符进行排序Stream.sorted()

String string = "adcbgekhs";

String sortedString = Stream.of( string.split("") )
                        .sorted()
                        .collect(Collectors.joining());

System.out.println(sortedString);    // abcdeghks

2. 使用Arrays.sort()对字符串进行排序

Arrays.sort ()也执行与Stream.sort()相同的操作。因此,在此解决方案中对字符串进行排序的步骤也保持相同。这次,我们创建一个新的字符数组,对数组进行排序,然后连接数组以生成排序后的字符串。

String string = "adcbgekhs";

//Convert string to char array
char[] chars = string.toCharArray();    

//Sort char array
Arrays.sort(chars);

//Convert char array to string
String sortedString = String.valueOf(chars);

System.out.println(sortedChars);    // abcdeghks

3.不使用sort()方法

如果我们不想使用内置的 Java API,我们可以使用Java 数组来迭代 String 的字符并在循环中对它们进行排序。

  • 使用toCharArray()方法将字符串转换为字符数组
  • 循环遍历数组元素并通过比较代码值来检查数组的交换元素
  • 循环结束后打印数组
String string = "adcbgekhs";
String sortedString = sortWithArray(string);
System.out.println(sortedString);

//The custom sorting function using arrays

static String sortWithArray(String str) {

    char arr[] = str.toCharArray();
    char temp;

    int i = 0;
    while (i < arr.length) {
      int j = i + 1;
      while (j < arr.length) {
        if (arr[j] < arr[i]) {
          temp = arr[i];
          arr[i] = arr[j];
          arr[j] = temp;
        }
        j += 1;
      }
      i += 1;
    }
    return String.copyValueOf(arr);
}

4.结论

本 Java 教程通过示例讨论按字母顺序对字符串进行排序的不同方法。我们学习了如何通过简单的数组和交换来使用Stream.sort()、Arrays.sort()和自定义sort()方法。


版权声明:本站文章,如无说明,均为本站原创,转载请注明文章来源。如有侵权,请联系博主删除。
本文链接:https://www.panziye.com/teach/8995.html
喜欢 (0)
请潘老师喝杯Coffee吧!】
分享 (0)
用户头像
发表我的评论
取消评论
表情 贴图 签到 代码

Hi,您需要填写昵称和邮箱!

  • 昵称【必填】
  • 邮箱【必填】
  • 网址【可选】