黑马程序员技术交流社区

标题: 【成都校区】Treeset的应用 [打印本页]

作者: Nikola    时间: 2018-5-2 00:44
标题: 【成都校区】Treeset的应用
刷题时候遇到treeset的应用,虽然课上没学到,但结合API和百度大概了解了下API的应用,其实Treeset是Sorted接口的实现类,其中支持两种排序方法,自然排序与定制排序,下面以自然排序调用compareTo(Object o)方法实现为例进行描述。
需求:
       (1)定义一个员工类Employee,包含三个属性:姓名(String name)、年龄(int age)、工资(int salary)
(2)创建5个对象装入TreeSet,按照工资从高到底排序输出结果(工资相同,按照年龄从低到高,工资和年龄都相同,按照姓名字典顺序排列,但是不能去重(姓名、年龄、工资都相同))
import java.util.Comparator;
import java.util.Scanner;
import java.util.TreeSet;

import com.heima.bean.employee;

public class linaxi_1 {

        public static void main(String[] args) {
                TreeSet<employee> tr = new TreeSet<employee>(new Comparator<employee>() {

                        public int compare(employee e1, employee e2) {
                                double num = (e2.getSalary()-e1.getSalary());
                                double age1 = num ==0?e1.getAge()-e2.getAge():num;
                                
                                
                                return (int) (num ==0? e1.getName().compareTo(e2.getName()):num);
                        
                        }
                });
               
                tr.add(new employee("张三",23,4000));
                tr.add(new employee("李四",24,1000));
                tr.add(new employee("周七",23,1000));
                tr.add(new employee("王五",25,5000));
               
                for (employee e : tr) {
                        System.out.println(e);
                }
        }

}





作者: 一叶微冬    时间: 2018-5-2 14:20
厉害了我的哥

作者: MHD    时间: 2018-5-2 14:23
直接看不懂
作者: 风萧萧9    时间: 2018-5-2 14:27
看看      
作者: 银狐从不湿手    时间: 2018-5-2 14:28
厉害了我的哥




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