黑马程序员技术交流社区
标题:
关于TreeSet的练习
[打印本页]
作者:
蓝枫
时间:
2014-4-10 20:44
标题:
关于TreeSet的练习
import java.util.*;
class Demo
{
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("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;
return -1;
}
}
输出结果是
cc
cba
abcd
hahaha
怎么没有aaa
复制代码
作者:
清风木扬
时间:
2014-4-10 21:00
cba aaa 长度一样 根据 if(s1.length()==s2.length()) return 0; 返回0 aaa没保存。
作者:
759345779
时间:
2014-4-10 21:12
class Demo
{
public static void main(String[] args)
{
TreeSet ts= new TreeSet(new StrLenComparator());
ts.add("abcd");
System.out.println(ts.add("cc"));
System.out.println( ts.add("cba"));
System.out.println(ts.add("aaa"));
System.out.println(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 s1.compareTo(s2);
return -1;
}
}
复制代码
可以把代码改成这样,添加对象的时候加上打印语句你就知道添加成功了没有,你原来的加上打印语句“aaa”添加不成功。要想添加成功你把比较器改一下,如上。
作者:
蓝枫
时间:
2014-4-10 21:36
恩,可以了,谢谢啊!
作者:
山治0712
时间:
2014-4-10 23:05
你的比较器有问题,如果两个字符串一样长就认为是同一字符串,先存的cba,再存aaa的时候发现和刚存的cba的长度一样,就不存了
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2