java学习笔记13--比较器(Comparable、Comparator)
java学习笔记13--比较器(Comparable、Comparator)
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学习笔记13--比较器(Comparable、Comparator)的更多相关文章
- java学习笔记(13) —— google GSON 实现json转化方法
1.配置struts.xml <action name="getGsonAction" class="com.test.action.json.GetGsonAct ...
- Java学习笔记-13.创建窗口和程序片
1.init()方法:程序片第一次被创建,初次运行初始化程序片时调用. start()方法:每当程序片进入web浏览器中,并且允许程序片启动他的常规操作时调用(特殊的程序片被stop()关闭):同样在 ...
- Java学习笔记13(面向对象六:super)
在创建子类对象时,父类的构造方法会先执行,因为子类中所有构造方法的第一行有默认的隐式super();语句 注意:父类构造方法第一行也有隐式的super(); 所有类都有一个"祖宗类" ...
- Java学习笔记13(equals()方法;toString()方法)
equals()方法: equals方法是Object类中的方法:Object是所有类的祖宗,所以所有类都有equals()方法: boolean equals(Object obj); equals ...
- 《Java学习笔记(第8版)》学习指导
<Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...
- 0028 Java学习笔记-面向对象-Lambda表达式
匿名内部类与Lambda表达式示例 下面代码来源于:0027 Java学习笔记-面向对象-(非静态.静态.局部.匿名)内部类 package testpack; public class Test1{ ...
- 20145330第五周《Java学习笔记》
20145330第五周<Java学习笔记> 这一周又是紧张的一周. 语法与继承架构 Java中所有错误都会打包为对象可以尝试try.catch代表错误的对象后做一些处理. 使用try.ca ...
- Java学习笔记4
Java学习笔记4 1. JDK.JRE和JVM分别是什么,区别是什么? 答: ①.JDK 是整个Java的核心,包括了Java运行环境.Java工具和Java基础类库. ②.JRE(Java Run ...
- 0032 Java学习笔记-类加载机制-初步
JVM虚拟机 Java虚拟机有自己完善的硬件架构(处理器.堆栈.寄存器等)和指令系统 Java虚拟机是一种能运行Java bytecode的虚拟机 JVM并非专属于Java语言,只要生成的编译文件能匹 ...
随机推荐
- 微信或手机浏览器在线显示office文件(已測试ios、android)
近期开发微信企业号,发现微信andriod版内置浏览器在打开文件方面有问题,可是ios版没有问题.原因是ios版使用的是safari浏览器 支持文档直接打开.可是andriod版使用的是腾讯浏览器x5 ...
- UML02-用例图
1.泛化表示一般和特殊的关系.用例之间存在泛化关系,参与者之间存在泛化关系,参与者和用例之间存在泛化关系. 2.画出用例图. 系统允许管理员通过磁盘加载存货数据来运行存货清单报告: 管理员通过从磁盘加 ...
- linux配置ssh+rsync
ssh 远程登录 sftp 文件共享 类似ftp ssh secure file transfer client scp 文件共享 类似cp ssh配置文件 /etc/ssh/s ...
- perl encode_utf8必须用在utf8环境
[root@wx03 mojo]# cat test.pl use Mojolicious::Lite; use JSON qw/encode_json decode_json/; use Encod ...
- 在TC(Total Commander)中添加启动Cygwin快捷键的方法
在TC(Total Commander)中添加启动Cygwin快捷键的方法 1.在Cygwin的安装目录下,增加文件tc-cygwin.bat(例如C:\cygwin-177\tc-cygwin.ba ...
- http协议与web本质
当你在浏览器地址栏敲入“http://www.csdn.net/”,然后猛按回车,呈现在你面前的,将是csdn的首页了(这真是废话,你会认为这是理所当然的).作为一个开发者,尤其是web开发人员,我想 ...
- 【Ubuntu】升到14,攻克了进入用户后没有菜单条导航栏的问题
控制台还能够进,用ctrl+alt+f1用老账号登录,用sudo adduser test新建立一个名字叫test的帐号 然后就能够进去了,可能是配置文件坏掉了
- Linux - VIM(VI)编辑器
VIM(VI)编辑器 简介: VI是一个命令行界面下的文本编辑工具,最早在1976年BILL Joy开发,当时的名字叫做ex.VI支持绝大多数操作系统(最早在BSD上发布),并且功能已经十分强大. 1 ...
- deflate——过时的网页压缩格式,最好禁用[转]
在设置GZip时,发现同时有个Deflate压缩设置,一开始并不了解Deflate压缩,于是便在启用GZip的同时,也启用了Deflate压缩.虽然同时设置GZip和Deflate压缩,并不影响网站的 ...
- 【HTML】让<pre>标签文本自动换行
利用<pre></pre>这个标签可以将其包起来的文字排版.格式,原封不动的呈现出来. 也就是说你输入的东西被原封不动的输出,包括你输入的空格之类的,不用 和<BR> ...