/*
练习:按照字符串长度排序。
字符串本身具备比较性。但是它的比较方式不是所需要的。
这时就只能使用比较器。
*/
import java.util.*;
class TreeSetTest
{
public static void main(String[] args)
{
TreeSet ts = new TreeSet(new StrLenComparator());
ts.add("abcd");
ts.add("cc");
ts.add("cba");
ts.add("aaa");
ts.add("z");
ts.add("hahaha");
Iterator it = ts.iterator();
while(it.hasNext())
{
System.out.println(it.next());
}
}
}class StrLenComparator implements Comparator{public int compare(Object o1,Object o2){String s1 = (String)o1;String s2 = (String)o2;/*if(s1.length()>s2.length())return 1;if(s1.length()==s2.length())return 0;*/int num = new Integer(s1.length()).compareTo(new Integer(s2.length()));if(num==0)return s1.compareTo(s2);return num;}}
/*"90 -7 0 18 2 45 4"将字符串中的数值进行排序。使用TreeSet完成。思路1,将字符串切割。2,可以将这些对象存入TreeSet集合。因为TreeSet自身具备排序功能。*/import java.util.*;class TreeSetTest2 {public static void main(String[] args) {ArrayList al = new ArrayList();String str = "90 -7 0 18 2 45 4";String[] arr = str.split(" ");TreeSet ts = new TreeSet();for(int x=0; x<arr.length; x++){//ts.add(new Integer(arr[x]));ts.add(Integer.parseInt(arr[x]));//}System.out.println(ts);}}