A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Nikola 中级黑马   /  2018-5-2 00:44  /  1419 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

刷题时候遇到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);
                }
        }

}




4 个回复

倒序浏览
一叶微冬 来自手机 初级黑马 2018-5-2 14:20:11
沙发
厉害了我的哥
回复 使用道具 举报
MHD 来自手机 初级黑马 2018-5-2 14:23:50
藤椅
直接看不懂
回复 使用道具 举报
风萧萧9 来自手机 初级黑马 2018-5-2 14:27:21
板凳
看看      
回复 使用道具 举报
银狐从不湿手 来自手机 初级黑马 2018-5-2 14:28:28
报纸
厉害了我的哥
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马