// SortingAnonOld.java // // old version -- this uses Comparator interface from 1.4.2 (before // generics) import java.util.*; // Example of how to sort an array several different ways public class SortingAnonOld { static String[] nameArray = {"Bob", "Fred", "Ralph", "Joe", "Wanda", "Joanna", "billy Joe", "jennifer", "John"}; public static void main(String[] args) { // print the original unsorted array System.out.println(""); printRuleAndArray("Original name list:"); // sorting by 'natural ordering' Arrays.sort(nameArray); printRuleAndArray("Sorted by 'natural ordering' " + "(lexicographic):"); // sorting by length Arrays.sort(nameArray, new Comparator() { public int compare(Object o1, Object o2) { return (((String) o1).length() - ((String) o2).length()); } }); printRuleAndArray("Sorted list by name length:"); // sorting alphabetically Arrays.sort(nameArray, new Comparator() { public int compare(Object o1, Object o2) { return (((String) o1).toLowerCase(). compareTo(((String) o2).toLowerCase())); } }); printRuleAndArray("Sorted list in alphabetical order:"); // sorting lexicographically by last letter Arrays.sort(nameArray, new Comparator() { public int compare(Object o1, Object o2) { return(((String) o1).charAt(((String) o1).length() - 1) - ((String) o2).charAt(((String) o2).length() - 1)); } }); printRuleAndArray("Sorted list in lexicographic order " + "of last letter:"); } static void printRuleAndArray(String rule) { System.out.println(rule); for (int i = 0; i < nameArray.length; i++) { System.out.println(nameArray[i]); } System.out.println(""); } }