和List
>方法,它允許我們指定自定義分類邏輯。 Collections.sort()
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class AlphanumericSort { public static void main(String[] args) { List<String> strings = new ArrayList<>(); strings.add("apple1"); strings.add("apple10"); strings.add("apple2"); strings.add("banana1"); strings.add("banana20"); strings.add("banana10"); strings.add("apple"); // Sort using a custom comparator Collections.sort(strings, new AlphanumericComparator()); System.out.println("Sorted strings:"); for (String str : strings) { System.out.println(str); } } static class AlphanumericComparator implements Comparator<String> { @Override public int compare(String s1, String s2) { int i = 0; while (i < s1.length() && i < s2.length()) { char c1 = s1.charAt(i); char c2 = s2.charAt(i); if (Character.isDigit(c1) && Character.isDigit(c2)) { int num1 = 0; int num2 = 0; while (i < s1.length() && Character.isDigit(s1.charAt(i))) { num1 = num1 * 10 + (s1.charAt(i) - '0'); i++; } while (i < s2.length() && Character.isDigit(s2.charAt(i))) { num2 = num2 * 10 + (s2.charAt(i) - '0'); i++; } return Integer.compare(num1, num2); } else if (Character.isDigit(c1)) { return 1; // Digits come after letters } else if (Character.isDigit(c2)) { return -1; // Digits come after letters } else if (c1 != c2) { return c1 - c2; // Compare characters } else { i++; } } return s1.length() - s2.length(); // Compare lengths if prefixes are equal } } }
正確處理字符串的字母數字性質。 上面的示例演示了這樣的比較器。 該比較器解析字符串,將字母和數字部分分開,並相應地對其進行比較。 這種方法避免了不必要的字符串轉換或外部庫,從而導致有效的排序。 >是否有任何內置的Java函數或庫簡化了字母數字字符串排序? Collections.sort()
有效分類java中的字母分類的字母列表在Java中進行仔細考慮的algorith和Algorith的實現,並且需要對Algorith進行分類的實現。 內置Comparator
方法使用高度優化的合併排序,在平均情況和最壞情況下提供O(n log n)時間複雜性。 但是,效率在很大程度上取決於您提供的Comparator
>
Comparator
將數字部分作為數字處理,而不是字符串。 Comparator
Comparator
Comparator
>您的null
>應該優雅地處理NullPointerExceptions
或空字符串,以防止null
。 考慮添加Collections.sort()
Comparator
Comparator
以上是Java排序字母數字字符串示例的詳細內容。更多資訊請關注PHP中文網其他相關文章!