功能:字符串直接排序,常常出現‘11’,‘12’等排在10后面缺在2,3等前面的情況,該排序器能在字符串能合理轉化為數字時按數字排序,從而能使數字字符串按真正的順序來,11,12等不再插隊;黨字符串不能合理轉化為數字時便仍然按字符串排序。
定義:
import java.util.Arrays; import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.regex.Pattern; public class StringComparator implements Comparator<String>{ @Override public int compare(String s1, String s2) { if(isInteger(s1) && isInteger(s2)) { int i1=Integer.parseInt(s1); int i2=Integer.parseInt(s2); return i1-i2; } return s1.compareTo(s2); } /** * 判斷字符串是否整數 * @param s * @return */ private static boolean isInteger(String s) { Pattern p=Pattern.compile("[0-9]+"); return p.matcher(s).matches(); } }
使用:
String[] arr= {"1","2","3","10","11","12","13","哈哈","嘻嘻"}; List<String> ls=Arrays.asList(arr); System.out.println("--------直接按字符串排序的結果---------"); Collections.sort(ls); for(String s:ls) { System.out.println(s); } System.out.println("--------利用StringComparator排序的結果---------"); Collections.sort(ls,new StringComparator()); for(String s:ls) { System.out.println(s); }
輸出:
--------直接按字符串排序的結果--------- 1 10 11 12 13 2 3 哈哈 嘻嘻 --------利用StringComparator排序的結果--------- 1 2 3 10 11 12 13 哈哈 嘻嘻
END