亲,帮忙解决一下这个问题

shine1324 2012-11-05 08:38:21
创建一个TreeSet对象,并在其中添加一些员工对象(Employee),其姓名,工资分别是:张三8000,李四6000,王五5600,马六7600,最后按照工资的大小,降序输出。(提示:让Employee对象实现comparable接口)






谢啦~坐等
...全文
282 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
小祥 2012-11-06
  • 打赏
  • 举报
回复
private 
程序员一灯 2012-11-06
  • 打赏
  • 举报
回复
引用 4 楼 diypyh 的回复:
忘了将结果输出: 王五:5600.0 李四:6000.0 马六:7600.0 张三:8000.0
亲.是降序输出哟....您的是降序?
pengsky2002 2012-11-06
  • 打赏
  • 举报
回复
引用 楼主 shine1324 的回复:
创建一个TreeSet对象,并在其中添加一些员工对象(Employee),其姓名,工资分别是:张三8000,李四6000,王五5600,马六7600,最后按照工资的大小,降序输出。(提示:让Employee对象实现comparable接口) 谢啦~坐等
引用 楼主 shine1324 的回复:
创建一个TreeSet对象,并在其中添加一些员工对象(Employee),其姓名,工资分别是:张三8000,李四6000,王五5600,马六7600,最后按照工资的大小,降序输出。(提示:让Employee对象实现comparable接口) 谢啦~坐等
我、亮点
diypyh 2012-11-06
  • 打赏
  • 举报
回复
引用 8 楼 zhou9898 的回复:
引用 4 楼 diypyh 的回复:忘了将结果输出: 王五:5600.0 李四:6000.0 马六:7600.0 张三:8000.0 亲.是降序输出哟....您的是降序?
升降序只要修改这里就可以:

    /**
     * 覆写Comparable接口的方法
     * 
     * 此方法用于对象的排序比较
     */
    public int compareTo(Employee emp) {
        if (this.salary > emp.salary) {
            return 1;
        } else if (this.salary < emp.salary) {
            return -1;
        } else {
            return 0;
        }
    }
将上面的代码,1改为-1,-1改为1
liubey_zff 2012-11-05
  • 打赏
  • 举报
回复
贴出代码 Employee代码

public class Employee implements Comparable<Employee> {
	
	private String name;
	private int salary;
	
	public Employee() {
		
	}
	
	public Employee(String name,int salary) {
		this.name = name;
		this.salary = salary;
	}
	
	/* (non-Javadoc)
	 * @see java.lang.Comparable#compareTo(java.lang.Object)
	 * 覆写Comparable接口的方法
	 */
	@Override
	public int compareTo(Employee o) {
		return salary - o.getSalary();
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getSalary() {
		return salary;
	}

	public void setSalary(int salary) {
		this.salary = salary;
	}
	
}
测试类

import java.util.Set;
import java.util.TreeSet;

public class EmployeeTest {

	public static void main(String[] args) {
		Set<Employee> emps = new TreeSet<Employee>();
		emps.add(new Employee("张三", 8000));
        emps.add(new Employee("李四", 6000));
        emps.add(new Employee("王五", 5600));
        emps.add(new Employee("马六", 7600));
        
        for (Employee emp : emps) {
            System.out.println(emp.getName() + ":" + emp.getSalary());
        }
	}

}
精髓就在compareTo上,compareTo的约定并没有指定返回值的大小,而只指定了返回值的符号。
liubey_zff 2012-11-05
  • 打赏
  • 举报
回复
此问题的考点应该就是复写Comparable中的compareTo方法了,effective java中有一种写法可以简化代码
diypyh 2012-11-05
  • 打赏
  • 举报
回复
忘了将结果输出: 王五:5600.0 李四:6000.0 马六:7600.0 张三:8000.0
diypyh 2012-11-05
  • 打赏
  • 举报
回复
帮你写了一个,看看吧:

package com.pyh.demo2;

public class Employee implements Comparable<Employee> {
	private String name;
	private double salary;

	public Employee() {
	}

	public Employee(String name, double salary) {
		this.name = name;
		this.salary = salary;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public double getSalary() {
		return salary;
	}

	public void setSalary(double salary) {
		this.salary = salary;
	}

	/**
	 * 覆写Comparable接口的方法
	 * 
	 * 此方法用于对象的排序比较
	 */
	public int compareTo(Employee emp) {
		if (this.salary > emp.salary) {
			return 1;
		} else if (this.salary < emp.salary) {
			return -1;
		} else {
			return 0;
		}
	}

}


package com.pyh.demo2;

import java.util.Set;
import java.util.TreeSet;

public class Demo10 {
	public static void main(String[] args) {
		Set<Employee> emps = new TreeSet<Employee>();
		emps.add(new Employee("张三", 8000));
		emps.add(new Employee("李四", 6000));
		emps.add(new Employee("王五", 5600));
		emps.add(new Employee("马六", 7600));

		for (Employee emp : emps) {
			System.out.println(emp.getName() + ":" + emp.getSalary());
		}
	}
}
shine1324 2012-11-05
  • 打赏
  • 举报
回复
因为刚刚申请的号,一直没用过,所以是0%啊
桃园闲人 2012-11-05
  • 打赏
  • 举报
回复
结帖率:0%

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧