排序算法扩展之对象排序
2016-03-06 19:59
323 查看
今天我们要学一个好玩的东西,那就是对象排序,之前都是对整数数组进行排序,今天我们就来做一个对象排序。这个核心思想就是借用关键字进行比较,以及开一个临时对象进行指针交换来达到排序效果,这里我写一个冒泡对象排序实例:在这个实例中,我们借用关键字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; } }
相关文章推荐
- 搭建SpringMVC4.x+Spring4.x+Hibernate4.x(非Maven版)
- 杭电OJ题目分类
- 方法重载规则
- From Facial Parts Responses to Face Detection: A Deep Learning Approach
- mysql数据库安装方法
- 【servlrt0.0】servlet简介
- OpenStack与Docker对比与描述
- [LeetCode][JavaScript]Gray Code
- iOS蓝牙学习(一)
- 爬虫实例抓取并download with Beautifulsoap
- C# 笔记(怕电脑抽疯,存起来)
- dp学习
- App上架流程
- Java 引用类解析
- OpenCV中ROI 总结
- 配置 maven 编译的 JDK 版本
- stm32 hal i2c 库读写sd3088时钟
- 软件测试 homework2
- 多分类问题中,实现不同分类区域颜色填充的MATLAB代码(demo:Random Forest)
- hbase 读写过程