1 回答

TA貢獻(xiàn)1827條經(jīng)驗(yàn) 獲得超8個(gè)贊
對(duì)字符串使用默認(rèn)排序?qū)⑹褂米值漤樞?,而您打算按?shù)字順序?qū)ψ址M(jìn)行排序(如果第一個(gè)數(shù)字相等,則按第二個(gè)數(shù)字排序)。實(shí)現(xiàn)此目的的一種方法是使用兩個(gè)比較器:
List<String> list = new ArrayList<>(Arrays.asList("96-1","91","94-2","100-2","94-1","95"));
System.out.println("Unsorted: "+list);
Comparator<String> primaryComparator =
? (a,b)->Integer.valueOf(a.split("-")[0])
? ? ? ? ? .compareTo(Integer.valueOf(b.split("-")[0]));
Comparator<String> secondaryComparator =
? (a,b)->Integer.valueOf(a.split("-")[1])
? ? ? ? ? .compareTo(Integer.valueOf(b.split("-")[1]));
list.sort(primaryComparator.thenComparing(secondaryComparator));
System.out.println("Sorted: "+list);
list.sort(primaryComparator.thenComparing(secondaryComparator).reversed());
System.out.println("Sorted in reverse: "+list);
至于比較器本身,我假設(shè)列表中的字符串始終有效,并且始終采用 形式\d+(-\d+)?,因此要么是一個(gè)整數(shù),要么是兩個(gè)用連字符分隔的整數(shù)。(如果不是這種情況,您可能需要使用自定義 Java 7 樣式比較器添加一些額外的檢查/驗(yàn)證,以使其比 Java 8 樣式的 lambda 更具可讀性。)
/.split("-")[0]將.split("-")[1]在連字符上拆分此字符串,并根據(jù)比較器獲取第一個(gè)或最后一個(gè)整數(shù)。然后它會(huì)將其轉(zhuǎn)換為帶有 的整數(shù)Integer.valueOf(...),并將使用內(nèi)置的默認(rèn)整數(shù)進(jìn)行比較Integer1.compareTo(Integer2)。
添加回答
舉報(bào)