В случае, у меня есть массив строк в следующем формате -Как отсортировать массив строк (в виде имен, объединенных с числами) в Java?
[ "Synthia 16", "Алисия 3", "Алисия 2", "Алисия 1", "Synthia 2"]
Список должен быть отсортирован по имени сначала, а затем следующий номер. Выход сортировки должен быть-
[ "Алисия 1", "Алисия 2", "Алисия 3", "Synthia 2", "Synthia 16"]
Я использовал comaparator сделать это с использованием Java:
import java.util.Comparator;
import java.util.Arrays;
public class SortList {
public static void main (String[] args) {
String[] names = {"synthia 16", "alicia 4", "alicia 19", "alicia 1", "synthia 2"};
System.out.println("Unsorted list:\n ");
displayList(names);
Arrays.sort(names, new nameComparator());
System.out.println("\nSorted list:\n");
displayList(names);
}
public static void displayList(String[] names) {
for(String name:names) {
System.out.println(name);
}
}
private static class nameComparator implements Comparator<String> {
@Override
public int compare(String s1, String s2) {
String[] s1NameNumPair = s1.split(" ");
String[] s2NameNumPair = s2.split(" ");
if (s1NameNumPair[0].compareTo(s2NameNumPair[0]) > 1) {
return 1;
} else if (s1NameNumPair[0].compareTo(s2NameNumPair[0]) < 1) {
return -1;
} else {
Double n1 = Double.parseDouble(s1NameNumPair[1]);
Double n2 = Double.parseDouble(s2NameNumPair[1]);
if (n1 > n2) { return 1; }
else if (n1 < n2) { return -1; }
else { return 0; }
}
}
}
}
Однако, используя такой компаратор, только сортирует массив по алфавиту по названию. Вот результат, который этот код генерирует:
Unsorted list:
synthia 16
alicia 4
alicia 19
alicia 1
synthia 2
Sorted list:
alicia 1
alicia 19
alicia 4
synthia 2
synthia 16
Как я могу получить правильный сортированный выход?
Связанный: [сравнение и thenComparing дает ошибку компиляции] (http://stackoverflow.com/questions/40500280/comparing-and-thencomparing-gives-compile-error). –