2011-02-03 16 views
7

jaki jest prosty sposób tworzenia lexicographical ordering listy ciągów przy użyciu guawy. zrobić to w ten sposób:uporządkowanie leksykograficzne listy ciągów przy użyciu guava

List<String> s = newArrayList(
    "susen", "soumen", "dipak", "abhi", "zylo", 
    "zala", "gautam", "gautom", "shaswasti", "saswati"); 
List<char[]> ts = newArrayList(transform(s, new Function<String, char[]>() { 
    @Override 
     public char[] apply(String input) { 
      return input.toCharArray(); 
     } 
    })); 
Collections.sort(ts, Chars.lexicographicalComparator()); 
s = transform(ts, new Function<char[], String>() { 
    @Override 
    public String apply(char[] input) { 
     return String.valueOf(input); 
    } 
}); 
System.out.println(s); 
+2

To jest przesada. Po prostu użyj Collections.sort w pakiecie java.util –

+0

tak! bardzo poprawny – gautamr

Odpowiedz

7

String implementuje porównywalne, a jej naturalny porządek jest porządku leksykograficznym. Wszystko co musisz zrobić, to

Collections.sort(s); 
1

Mówiąc prościej (od String narzędzi Comparable):

List<String> s = ... 
Collections.sort(s); 
8

Jeśli nie chcesz porządek w miejscu, a chciałbyś używać guawa, sprawdź Ordering.

Ordering.natural().sortedCopy(yourInputThatIsIterableAndHasStrings); 

czyli

Ordering.usingToString().sortedCopy(yourInputThatIsIterableThatYouWantToSortBasedOnToString); 

Jeśli chcesz sortować w miejscu, to należy po prostu użyć Collections.sort(...).

Mam nadzieję, że to pomoże.

+0

jest też 'immutableSortedCopy', aby uzyskać' ImmutableList'. – Tom

Powiązane problemy