排序算法扩展之对象排序

今天我们要学一个好玩的东西,那就是对象排序,之前都是对整数数组进行排序,今天我们就来做一个对象排序。这个核心思想就是借用关键字进行比较,以及开一个临时对象进行指针交换来达到排序效果,这里我写一个冒泡对象排序实例:在这个实例中,我们借用关键字Key来进行比较排序。通过指针的交换来达到数值捆绑,同时这里也用到一个小的知识点那就是私有的变量我们要写get函数来获得。每个对象中要写tostring用来输出显示。总的而言,对象排序还是建立在之前学过的几个排序算法之上的。

package cn.hncu.sorts;

import com.sun.org.apache.bcel.internal.generic.SWAP;

public class SortObject {
	public static void main(String[] args) {
		DateObject[] datas=new DateObject[6];
		datas[0]=new DateObject(1.2,"jack",new MyDate(1991, 10, 10));
		datas[1]=new DateObject(-12,"miku",new MyDate(1989, 7, 10));
		datas[2]=new DateObject(6.52,"lixi",new MyDate(1995, 4, 7));
		datas[3]=new DateObject(11.32,"lol",new MyDate(1991, 2, 12));
		datas[4]=new DateObject(-11.2,"naxi",new MyDate(1988, 8, 18));
		datas[5]=new DateObject(15.05,"ailun",new MyDate(1992, 07, 10));
		
		bubbleSort(datas);
		for (DateObject data:datas) {
			System.out.println(data);
		}
		
	}

	private static void bubbleSort(DateObject[] datas) {
		for(int i=0;i<datas.length-1;i++){
			for (int j = 0; j < datas.length-1-i; j++) {
				if(datas[j].getKey()>datas[j+1].getKey()){
					swap(datas,j,j+1);
				}
			}
		}
	}

	private static void swap(DateObject[] datas, int j, int i) {
		DateObject temp=datas[i];
		datas[i]=datas[j];
		datas[j]=temp;
	}

}
class MyDate{
	int year,month,day;
	public MyDate(int year, int month, int day) {
		this.year = year;
		this.month = month;
		this.day = day;
	}

	@Override
	public String toString() {
		return "MyDate [year=" + year + ", month=" + month + ", day=" + day
				+ "]";
	}
	
}
class DateObject{
	private double key;
	String name;
	MyDate birth;
	
	public DateObject(double key, String name, MyDate birth) {
		this.key = key;
		this.name = name;
		this.birth = birth;
	}
	

	@Override
	public String toString() {
		return "DateObject [key=" + key + ", name=" + name + ", birth=" + birth
				+ "]";
	}


	public double getKey() {
		return key;
	}
}


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值