import java.util.Comparator;
import java.util.TreeSet;
import com.heima.bean.Person;
/*
* TreeSet集合是用来对元素进行排序的,同时也可以保证元素的唯一
*/
public class Demo3_TreeSet {
public static void main(String[] args) {
//demo1();
//demo2();
//demo3();
//demo4();
TreeSet<String> ts = new TreeSet<>(new CompareByLen());
ts.add("aaaa");
ts.add("nba");
ts.add("cba");
ts.add("sa");
ts.add("aaabbbbbcccc");
System.out.println(ts);
}
private static void demo4() {
TreeSet<Person> ts = new TreeSet<>();
ts.add(new Person("zhangsan",13));
ts.add(new Person("lisi",44));
ts.add(new Person("wangwu",25));
ts.add(new Person("zhaoliu",56));
System.out.println(ts);
}
private static void demo3() {
TreeSet<Person> ts = new TreeSet<>();
ts.add(new Person("张三",13));
ts.add(new Person("李四",44));
ts.add(new Person("王五",25));
ts.add(new Person("赵六",56));
System.out.println('张'+0);
System.out.println('李'+0);
System.out.println('王'+0);
System.out.println('赵'+0);
System.out.println(ts);
}
private static void demo2() {
/*
* 当compareTo方法返回0,集合中只有一个元素
* 当compareTo方法返回1,集合中元素怎么存就怎么取
* 当compareTo方法返回-1,集合中元素倒序存储
*/
TreeSet<Person> ts = new TreeSet<>();
ts.add(new Person("张三",13));
ts.add(new Person("李四",44));
ts.add(new Person("周奇",44));
ts.add(new Person("王五",25));
ts.add(new Person("赵六",56));
System.out.println(ts);
}
private static void demo1() {
TreeSet<Integer> ts = new TreeSet<>();
ts.add(1);
ts.add(1);
ts.add(3);
ts.add(3);
ts.add(2);
ts.add(2);
System.out.println(ts);
}
}
class CompareByLen implements Comparator<String> {
@Override
public int compare(String s1, String s2) {
int num = s1.length() - s2.length();
return num == 0 ? s1.compareTo(s2):num;
}
}
TreeSet的几个练习(不使用比较器)
最新推荐文章于 2023-03-20 18:01:28 发布