Comparable接口的作用
之前Arrays类中存在sort()方法,此方法可以直接对对象数组进行排序。
Comparable接口
可以直接使用java.util.Arrays类进行数组的排序操作,但对象所在的类必须实现Comparable接口,用于指定排序接口。
Comparable接口的定义如下:
public interface Comparable<T>{
public int compareTo(T o);
}
此方法返回一个int类型的数据,但是此int的值只能是一下三种:
1:表示大于
-1:表示小于
0:表示相等
要求:定义一个学生类,里面有姓名,年龄,成绩三个属性,要求按成绩由高到低排序,如果成绩相等,则按照年龄由低到高排序。
package com.itmyhome;
import java.util.Arrays;
class Student implements Comparable<Student>{
private String name;
private int age;
private float score;
public Student(String name,int age,float score){
this.name = name;
this.age = age;
this.score = score;
}
@Override
public int compareTo(Student stu) { //覆写compareTo方法实现排序规则的应用
if(this.score>stu.score){
return -1;
}else if(this.score<stu.score){
return 1;
}else{
if(this.age>stu.age){
return 1;
}else if(this.age<stu.age){
return -1;
}else{
return 0;
}
}
}
public String toString(){
return "姓名:"+this.name+", 年龄:"+this.age+", 成绩:"+this.score;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public float getScore() {
return score;
}
public void setScore(float score) {
this.score = score;
}
}
public class T {
public static void main(String[] args) throws Exception{
Student stu[] = {new Student("张三",22,80f)
,new Student("李四",23,83f)
,new Student("王五",21,80f)};
Arrays.sort(stu); //进行排序操作
for (int i = 0; i < stu.length; i++) {
Student s = stu[i];
System.out.println(s);
}
}
}
分析比较器的排序原理
实际上比较器的操作,就是经常听到的二叉树的排序算法。
排序的基本原理:使用第一个元素作为根节点,之后如果后面的内容比根节点小,则放在左子树,如果内容比根节点的内容要大,则放在右子树。
package com.itmyhome;
class BinaryTree {
class Node { // 声明一个节点类
private Comparable data; // 保存具体的内容
private Node left; // 保存左子树
private Node right; // 保存右子树
public Node(Comparable data) {
this.data = data;
}
public void addNode(Node newNode) {
// 确定是放在左子树还是右子树
if (newNode.data.compareTo(this.data) < 0) { // 内容小,放在左子树
if (this.left == null) {
this.left = newNode; // 直接将新的节点设置成左子树
} else {
this.left.addNode(newNode); // 继续向下判断
}
}
if (newNode.data.compareTo(this.data) >= 0) { // 放在右子树
if (this.right == null) {
this.right = newNode; // 没有右子树则将此节点设置成右子树
} else {
this.right.addNode(newNode); // 继续向下判断
}
}
}
public void printNode() { // 输出的时候采用中序遍历
if (this.left != null) {
this.left.printNode(); // 输出左子树
}
System.out.print(this.data + "\t");
if (this.right != null) {
this.right.printNode();
}
}
};
private Node root; // 根元素
public void add(Comparable data) { // 加入元素
Node newNode = new Node(data); // 定义新的节点
if (root == null) { // 没有根节点
root = newNode; // 第一个元素作为根节点
} else {
root.addNode(newNode); // 确定是放在左子树还是放在右子树
}
}
public void print() {
this.root.printNode(); // 通过根节点输出
}
};
public class T2 {
public static void main(String args[]) {
BinaryTree bt = new BinaryTree();
bt.add(8);
bt.add(3);
bt.add(3);
bt.add(10);
bt.add(9);
bt.add(1);
bt.add(5);
bt.add(5);
System.out.println("排序之后的结果:");
bt.print();
}
};
另一种比较器:Compartor
如果一个类已经开放完成,但是在此类建立的初期并没有实现Comparable接口,此时肯定是无法进行对象排序操作的,所以为了解决这一的问题,java又定义了另一个比较器的操作接口 Comparator 此接口定义在java.util包中,接口定义如下:
public interface Comparator<T>{
public int compare(T o1,T o2);
boolean equals(Object obj);
}
MyComparator.java
package com.itmyhome;
import java.util.Comparator;
public class MyComparator implements Comparator<Student> { //实现比较器
@Override
public int compare(Student stu1, Student stu2) {
// TODO Auto-generated method stub
if(stu1.getAge()>stu2.getAge()){
return 1;
}else if(stu1.getAge()<stu2.getAge()){
return -1;
}else{
return 0;
}
}
}
package com.itmyhome;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
class Student {
private String name;
private int age;
public Student(String name,int age ){
this.name = name;
this.age = age;
}
public String toString(){
return "姓名:"+this.name+", 年龄:"+this.age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
public class T {
public static void main(String[] args) throws Exception{
Student stu[] = {new Student("张三",23)
,new Student("李四",26)
,new Student("王五",22)};
Arrays.sort(stu,new MyComparator()); //对象数组进行排序操作
List<Student> list = new ArrayList<Student>();
list.add(new Student("zhangsan",31));
list.add(new Student("lisi",30));
list.add(new Student("wangwu",35));
Collections.sort(list,new MyComparator()); //List集合进行排序操作
for (int i = 0; i < stu.length; i++) {
Student s = stu[i];
System.out.println(s);
}
System.out.println("*********");
for (int i=0;i<list.size();i++){
Student s = list.get(i);
System.out.println(s);
}
}
}
分享到:
相关推荐
尚硅谷康师傅java学习笔记。 、2020-4-5 java学习笔记 2020-4-6 java笔记 ---内部类 2020-4-6 java笔记 ---异常 2020-4-6 java笔记 --多线程 2020-4-8 java笔记 String类 2020-4-9 java 比较器 2020-4-10 java笔记 ...
本文,先介绍Comparable 和Comparator两个接口,以及它们的差异;接着,通过示例,对它们的使用方法进行说明
6.5. This关键字 6-13 6.6. 访问控制符 6-13 6.7. 构造方法 6-13 6.8. 数据和方法的隐藏―――封装 6-14 6.9. 方法的重载 6-15 7. 六•高级语言特性 7-15 7.1. 封装 (encapsulation) 7-15 7.2. 继承 (inherit) 7-16 ...
Comparable和Comparator接口都可用作普通意义上对象间的比大小,但两个接口在实例化方面的用法不尽相同,接下来我们就来详细对比Java中的Comparable排序接口和Comparator比较器接口
1.10 Java中Comparable和Comparator实现对象比较 1.11 Java中的JNDI (Java命名与目录接口) 1.12 Java事件处理机制与“恋爱关系” 1.13 Java代码优化编程 1.14 Java数组浅析 。。。。。。
我的学习笔记的书本课程来自于:《Thinking in Java》和《Head First Java》 视频课程主要来自于:廖雪峰老师《Java 基础课程》 如涉及版权侵犯请联系我更正。 初来乍到,文笔稚嫩,学识浅薄,请多指教。
想学习java的爱好者必备,内容涉及比较全面,比较适合初学者学习使用
清华大学java学习笔记,讲得比较细,比较全,也比较彻底
Java学习笔记及其与C++的比较
Java字符串学习笔记,比较系统的讲解了Java的字符串知识
良葛格Java学习笔记html.rar 要想提高看看这个!他讲的比较透彻!
主要介绍了java 中Comparable与Comparator详解与比较的相关资料,需要的朋友可以参考下
简单的用commons的jar包,运用其中Comparator的方法,希望对你有所帮助。
教你学会Comparator和Comparable
一个Java+ajax写的登录实例,附有JAVA源文件,JAVA新手朋友可以学习一下。 JAVA+JSP的聊天室 8个目标文件 简单 JavaScript万年历 显示出当前时间及年份,还可以选择年份及月份和日期 Java编写的HTML浏览器 一...
方法是Java学习中比较重要的部分,也是必须要明白的内容,这个方法讲了方法的定义、使用、重载以及构造方法等。
java面试题大全-葵花宝典-出现率比较高的面试题
本资源就是自己平时学习C#时记的笔记,和大家分享一下可能比较乱,希望大家慢慢去看
Java mysql-connector-java-5.0.4-bin.jar dom4j-1.6.1.jar等类库打包下载,主要是以下几款类库的打包下载:commons-httpclient-3.0.1.jar、dom4j-1.6.1.jar、jaxen-...日常的编程中,或许这些都是比较有用的Java类库。
PSIM中滞环控制器,环宽、频率、占空比等等可以自己设定。