Java 中的自然排序字串比較
人類所理解的「自然」排序順序是根據字串的數值和按字母順序排列的組件。這與預設的字典順序不同,預設的字典順序優先考慮字元順序。
在 Java 中,沒有專門為自然排序順序設計的內建函數。但是,您可以使用以下外部實作來實現此行為:
<code class="java">// NaturalOrderComparator.java // License: Cougaar Open Source License import java.util.Comparator; public class NaturalOrderComparator implements Comparator<String> { @Override public int compare(String s1, String s2) { // Split strings into tokens String[] s1Tokens = s1.split("(?<=\D)(?=\d)|(?<=\d)(?=\D)"); String[] s2Tokens = s2.split("(?<=\D)(?=\d)|(?<=\d)(?=\D)"); // Compare tokens one by one int i = 0; while (i < Math.min(s1Tokens.length, s2Tokens.length)) { try { int n1 = Integer.parseInt(s1Tokens[i]); int n2 = Integer.parseInt(s2Tokens[i]); // Numerical comparison if (n1 != n2) { return n1 - n2; } } catch (NumberFormatException e) { // Alphabetical comparison int comparison = s1Tokens[i].compareTo(s2Tokens[i]); if (comparison != 0) { return comparison; } } i++; } // If all tokens are equal, compare lengths if (s1Tokens.length != s2Tokens.length) { return s1Tokens.length - s2Tokens.length; } // Strings are identical return 0; } }</code>
以上是如何用Java實現自然排序字串比較?的詳細內容。更多資訊請關注PHP中文網其他相關文章!