2017-05-03 67 views
0

林有麻煩找出一種方法來排序某類號碼我嘗試頭腦風暴的方式進行排序,但認爲社會有一個答案已經數量在java中排序

什麼我試着理清像數字:

  1. FA8Z-7406024-AB
  2. DS7Z-6632394-d
  3. AA8Z-6632394-S
  4. SR3Z-15342-H
  5. TR3 Z-72B39842-S
  6. TR3Z-7239842-S

的排序方法應該由中間先走,然後是第一個數字,然後最後的最後一個號碼

如果我的列表進行排序以上,它應該是這樣的:

  1. SR3Z-15342-H
  2. AA8Z-6632394-S
  3. DS7Z-6632394-S
  4. TR3Z-7239842-S
  5. TR3Z-72B39842-S
  6. FA8Z-7406024-AB

如果中間數中有一封信,信應該被忽略,但它應該後進行排序任何類似數字但沒有字母的數字(IE TR3Z's)。

編輯:固定例子

+4

創建[比較](https://docs.oracle.com/javase/7/docs/api/java/util/Comparator.html)。 – Compass

+0

併發布代碼後,如果您有問題,請指定它們。 – SomeDude

+1

請閱讀[如何創建最小,完整和可驗證的示例](http://stackoverflow.com/help/mcve) –

回答

0

假設所有的entried遵循相同的格式,這應該做,不同的是FA8Z-7406024-AB將在排序後的數組,第二元件由於基於中間值比較:

Comparator<String> comparator = (s1, s2) -> { 
    String[] tokens1 = s1.split("-"); 
    String[] tokens2 = s2.split("-"); 

    int number1 = Integer.parseInt(tokens1[1].replaceAll("[^0-9]", "")); 
    int number2 = Integer.parseInt(tokens2[1].replaceAll("[^0-9]", "")); 

    //Compare the numbers 
    if(number1 - number2 == 0 && tokens1[1].length() == tokens2[1].length()){ 
     //Compare the Strings 
     return tokens1[0].compareTo(tokens2[0]) == 0 ? tokens1[2].compareTo(tokens2[2]) : tokens1[0].compareTo(tokens2[0]); 
    }else if (tokens1[1].length() != tokens2[1].length()){ 
     return tokens1[1].length() - tokens2[1].length(); 
    }else{ 
     return number1 - number2; 
    } 
}; 

下面是一個例子:

List<String> list = Arrays.asList("FA8Z-7406024-AB", "DS7Z-66329294-D", "AA8Z-66329294-S", "SR3Z-15342-H", "TR3Z-72B381942-S", "TR3Z-72381942-S"); 

Collections.sort(list, comparator); 

System.out.println(list); 
+1

請提供足夠的解釋,不要鼓勵回答不清楚的問題! – Yahya