Java容器Treeset的两种排序方法

TreeSet支持两种排序方式:自然排序、定制排序



1、自然排序:自然排序下,集合元素必须是实现了Comparable接口的类的对象。
           也就是说,在这种排序方式下需要实现Comparable接口。
           覆盖此接口中的compareTo(Object obj)方法,定义目标的比较方法
package edu.hnsd1.dao;

import java.util.Iterator;
import java.util.TreeSet;
/**
 * 上机实验:CPU有型号、单价、主频等属性
 * 构造这样的对象添加到Treeset中,并对其进行降序输出。
 * @author Blue Jey
 *自然排序方式
 */

public class TreeSetImpl {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
      TreeSet treeset=new TreeSet();
      treeset.add(new computer1("联想ThinkPadE431",3333,3));
      treeset.add(new computer1("宏基",3000,3));
      treeset.add(new computer1("Dell",4000,3));
 
      Iterator itera=treeset.iterator();
      while(itera.hasNext()){
    	  System.out.println(itera.next());
      }
      
	}

}
class computer1 implements Comparable {
    private String Type;//电脑的型号
    private int Price;//电脑的单价
    private int MainFrequency;//电脑的主频/MHZ
    public computer1(String t1,int t2,int t3){
    	this.setComputer1(t1, t2, t3);
    }
    public void setComputer1(String t1,int t2,int t3){
    	this.Type=t1;
    	this.Price=t2;
    	this.MainFrequency=t3;
    }
    
	@Override
	public int compareTo(Object arg0) {
		// TODO Auto-generated method stub
		int ret=0;
		if(!(arg0 instanceof computer1))  
			   throw new RuntimeException("对象不对!");  
		computer1 temp=(computer1)arg0;
		if(this.equals(temp)){
		System.out.println("HELLO WORD!");
		}
		ret=this.Price-temp.Price;
		if(ret==0){
			ret=this.MainFrequency-temp.MainFrequency;
		}
		return -ret;
	}
	public String toString(){
		return this.Type+" "+this.Price+" "+this.MainFrequency;
	}</span>
2、定制排序:通过构造方法指定TreeSet的比较器进行排序,实现 int compare(T o1,T o2)的比较方法。
package edu.hnsd1.dao;

import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;

/**
 * 上机实验:CPU有型号、单价、主频等属性 构造这样的对象添加到Treeset中,并对其进行降序输出。
 * 
 * @author Blue Jey 自然排序方式
 */

public class TreeSetImpl {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		TreeSet treeset = new TreeSet(new newComparator());
		treeset.add(new computer2("联想ThinkPadE431", 3333, 3));
		treeset.add(new computer2("宏基", 3000, 3));
		treeset.add(new computer2("Dell", 4000, 3));

		Iterator itera = treeset.iterator();
		while (itera.hasNext()) {
			System.out.println(itera.next());
		}

	}

}

class computer2 {
	private String Type;// 电脑的型号
	private int Price;// 电脑的单价
	private int MainFrequency;// 电脑的主频/MHZ

	public computer2(String t1, int t2, int t3) {
		this.setcomputer2(t1, t2, t3);
	}

	public void setcomputer2(String t1, int t2, int t3) {
		this.Type = t1;
		this.Price = t2;
		this.MainFrequency = t3;
	}

	public int getPrice() {
		return this.Price;
	}

	public int getMF() {
		return this.MainFrequency;
	}

	public String toString() {
		return this.Type + " " + this.Price + " " + this.MainFrequency;
	}

}

class newComparator implements Comparator {

	@Override
	public int compare(Object arg0, Object arg1) {
		int ret = 0;
		computer2 temp = (computer2) arg0;
		computer2 temp1 = (computer2) arg1;
		ret = temp.getPrice() - temp1.getPrice();
		if (ret == 0) {
			ret = temp.getMF() - temp1.getMF();
		}
		return -ret;
	}

}





package com.oracle.javabase.ch4.ex01;

/*数组排序-补充*/
public class TestArraySortAdd {
	 public static void main(String[] args) {
		//补充1:自定义类实现Comparable接口
		Person[] persons = new Person[]{
				new Person(1, "xiaoli", 21),
				new Person(3, "xiaoliu", 25),
				new Person(2, "xiaozhao", 23)};
		java.util.Arrays.sort(persons);
		System.out.println(java.util.Arrays.toString(persons));
		
		//补充2: 自定义类借助Comparator接口
		User[] users = new User[]{
				new User(1, "xiaoli", 21),
				new User(3, "xiaoliu", 25),
				new User(2, "xiaozhao", 23)};
		java.util.Arrays.sort(users, new UserComparator());
		System.out.println(java.util.Arrays.toString(users));
	}
}

//自定义类实现Comparable接口
class Person implements Comparable<Person>{//接口,泛型:以后学习
	int id;
	String name;
	int age;
	public Person(int id, String name, int age){
		this.id = id;
		this.name = name;
		this.age = age;
	}
	@Override
	public int compareTo(Person p) {
		//return this.age < p.age ? -1: (this.age > p.age ? 1 : 0);
		if (this.age > p.age){
			return 1;
		} else if (this.age < p.age){
			return -1;
		} else {
			return 0;
		}
	}

	public String toString(){
		return id + "," + name + "," + age;
	}
}

class User{
	int id;
	String name;
	int age;
	public User(int id, String name, int age) {
		this.id = id;
		this.name = name;
		this.age = age;
	}
	@Override
	public String toString() {
		return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
	}
}

class UserComparator implements java.util.Comparator<User>{
	@Override
	public int compare(User o1, User o2) {
		return o1.age - o2.age;
	}
	
}



















                
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Java程序设计》课程实验指导书程序代码(答案)(实验四:java继承与多态),个人原创,仅供参考与交流。 希望多多交流,共同进步! 实验四 java继承与多态 一、实验目的: 掌握继承、多态的概念与实现方法; 掌握包和接口的定义和使用方法; 了解JAVA语言实现多继承的途径; 二、实验内容: 1.分别编写两个类Point2D,Point3D来表示二维空间和三维空间的点,使之满足下列要求: (1) Point2D有两个整型成员变量x, y (分别为二维空间的X,Y方向坐标),Point2D的构造方法要实现对其成员变量x, y的初始化。 (2)Point2D有一个void型成员方法offset(int a, int b),它可以实现Point2D的平移。 (3)Point3D是Point2D的直接子类,它有有三个整型成员变量x,y,z (分别为三维空间的X,Y,Z方向坐标),Point3D有两个构造方法:Point3D(int x,int y,int z)和Point3D(Point2D p,int z),两者均可实现对Point3D的成员变量x, y,z的初始化。 (4)Point3D有一个void型成员方法offset(int a, int b,int c),该方法可以实现Point3D的平移。 (5)在Point3D中的主函数main()中实例化两个Point2D的对象p2d1,p2d2,打印出它们之间的距离,再实例化两个Point2D的对象p3d1,p3d2,打印出他们之间的距离。 2.定义抽象类Shape,抽象方法为showArea(),求出面积并显示,定义矩形类Rectangle,正方形类Square,圆类 Circle,根据各自的属性,用showArea方法求出各自的面积,在main方法中构造3个对象,调用showArea方法。 定义接口DiagArea,其中包含方法double getDiagonal()求对角线长, double getArea()求面积,定义一个矩形类,实现此接口,并自行扩充成员变量和方法,定义一个正方形类继承矩形类(如矩形有长w和宽h,正方形有边x,并有相应的构造函数,有一个方法中一次直接显示边长、面积和对角线长),在另一类中的主方法里使用测试该类。 三、实验要求: 1. 能实现类的继承关系; 2. 用多种方法创建各个类的对象; 3. 程序应包括各个被调用方法的执行结果的显示。 4. 写出实验报告。要求记录编译和执行Java程序当中的系统错误信息提示,并给出解决办法。(附运行界面、源代码)。 四、实验步骤: 1.(第1题)定义Point2D,及定义它的属性和方法; 定义子类Point3D,及定义它的属性和方法;在Point3D中的主函数main()中实例化两个Point2D的对象,并通过这两个对象调用它们的属性和方法,输出方法执行结果。 2.(第2题)定义抽象类Shape,抽象方法为showArea(),再定义矩形类Rectangle,正方形类Square,圆类 Circle,和各自的属性。定义主类、主方法,在main方法中构造3个对象,调用showArea方法;定义接口DiagArea,其中包含方法double getDiagonal(),在主main方法中输出方法执行结果。 五、自做作实验 1.定义一个描述人的基本类,该类包括人的性别和出生日期两个数据成员,以及设置和获取这些属性值的方法成员;再定义一个大学生类,使大学生类具有人的所有属性外,还具有姓名、学号,大学入学成绩,籍贯属性以及设置和获取这些属性值的方法成员;编写完整的程序,完成一个具有班级学生信息管理功能的程序。 2创建一个接口Shape,其中有抽象方法area,类Circle 、Rectangle实现area方法计算其面积并返回。又有Star实现Shape的area方法,其返回值是0,Star类另有一返回值boolean型方法isStar;在main方法里创建一个Vector,根据随机数的不同向其中加入Shape的不同子类对象(如是1,生成Circle对象;如是2,生成Rectangle对象;如是3,生成Star对象)。然后将Vector中元素依次取出,判断其是否为Star类。如是返回其是个Star。否则返回其面积。 3..学校中有老师和学生两类人,而在职研究生既是老师又是学生,对学生的管理和对教师的管理在他们身上都有体现。 1)设计两个信息管理接口StudentManageInterface和TeacherManageInterface。其中,StudentInterface接口包括setFee()方法和getFee()方法,分别用于设置和获取学生的学费;TeacherInterface接口包括setPay()方法和getPay()方法,分别用于设置和获取教师的工资 2) 定义一个研究生类Graduate,实现StudentInterface接口和TeacherInterface接口,它定义的成员变量有name(姓名)、sex(性别)、age(年龄)、fee(每学期学费)、pay(月工资)。 3) 创建一个姓名为“zhangsan”的研究生,统计他的年收入和学费,如果收入减去学费不足2000元,则输出“provide a loan”(需要贷款)信息。 提示: 1)定义两个接口,分别在其中申明两个方法。 2)定义主类Graduate,实现这两个接口。 3)定义主类的成员变量,和构造方法。 4)给出四个接口方法的实现。 5)给出一个计算是否需要贷款的方法,在里面统计年收入和学费,并输出是否需要贷款的信息。 6)写main方法。在其中创建一个姓名为“zhangsan”的研究生,调用计算是否需要贷款的方法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值