黑马程序员技术交流社区

标题: TreeSet怎么实现升序降序排列 [打印本页]

作者: 技术小牛    时间: 2016-4-19 22:36
标题: TreeSet怎么实现升序降序排列


作者: 小哒哒    时间: 2016-4-19 22:36
前 - 后   升序
后 - 前 降序排列

作者: 小哒哒    时间: 2016-4-19 22:39
前 - 后   升序                                       后 - 前          降序排列
作者: liudh1    时间: 2016-4-20 13:53
自然排序就是升序,:储存在集合中的对象必须实现comparable借口
比较器排序:就是在set的构造方法中传一个Comparator的子类对象,
Comparator是一个接口,所以需要一个类实现该接口,并重写comapre(To1,To2)方法,

作者: 东方乔恩    时间: 2016-4-20 23:28
如楼上所说,Compare(T2,T1)就可以降序排列了
作者: 18895700133    时间: 2016-4-26 21:27
3楼说的是对的
作者: 18895700133    时间: 2016-4-26 21:31
import java.util.Comparator;
import java.util.TreeMap;

import com.studyself.bean.Person;

public class Demo7_TreeMap {
    public static void main(String[] args) {
    //    demo1();
        TreeMap<Person, String> tm = new TreeMap<>(new Comparator<Person>() {

            @Override
            public int compare(Person o1, Person o2) {
                // TODO Auto-generated method stub
                int num = o1.getName().compareTo(o2.getName());
                return num == 0 ? o1.getAge() - o2.getAge() : num;
            }
        });
        tm.put(new Person("张三", 23), "北京");
        tm.put(new Person("李四", 24), "上海");
        tm.put(new Person("王五", 25), "广州");
        tm.put(new Person("赵六", 26), "深圳");
        System.out.println(tm);
    }

    private static void demo1() {
        TreeMap<Person, String> tm = new TreeMap<>();
        tm.put(new Person("张三", 23), "北京");
        tm.put(new Person("李四", 24), "上海");
        tm.put(new Person("王五", 25), "广州");
        tm.put(new Person("赵六", 26), "深圳");
        System.out.println(tm);
    }
}





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2