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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 某某帅 中级黑马   /  2016-9-17 20:55  /  478 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

1.分析以下需求,并用代码实现:
        (1)定义一个员工类Employee,包含三个属性:姓名(String name)、年龄(int age)、工资(int salary)
        (2)创建5个对象装入TreeSet,按照工资从高到底排序输出结果(工资相同,按照年龄从低到高,工资和年龄都相同,
                按照姓名字典顺序排列,但是不能去重(姓名、年龄、工资都相同))

1 个回复

倒序浏览
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);
                }
        }

}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马