教你使用Comparable接口

Comparable接口,直译过来也就是比较器,通常用于实现指定对象的排序规则。Comparable接口的定义如下:

网站建设哪家好,找成都创新互联公司!专注于网页设计、网站建设、微信开发、小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了奎文免费建站欢迎大家使用!

 
 
 
  1. public interface Comparable{  
  2.    public int compareTo(T o);  

compareTo()方法返回一个int类型的值,此返回值只有以下三个:

1:表示大于

-1:表示小于

0:表示等于

基于Comparable接口实现的二叉树操作

 
 
 
  1. /**  
  2.  *   
  3.  */ 
  4. package com.java.thread;  
  5.  
  6. /**  
  7.  * @author JimyChen  
  8.  * @date   2009-9-1  
  9.  */ 
  10. class BinaryTree{  
  11.     class Node{  
  12.        private Comparable data;  
  13.        private Node left;  
  14.        private Node right;  
  15.        public void addNode(Node newNode){  
  16.            if(newNode.data.compareTo(this.data) < 0){//这里关键要搞清楚这个this的含义  
  17.                if(this.left==null){  
  18.                   this.left=newNode;   
  19.            }else{  
  20.                   this.left.addNode(newNode);    
  21.              }  
  22.          }  
  23.            if(newNode.data.compareTo(this.data) >= 0){  
  24.                if(this.right==null){  
  25.                   this.right=newNode;   
  26.            }else{  
  27.                   this.right.addNode(newNode);    
  28.              }  
  29.          }  
  30.       }  
  31.  public void printNode(){  
  32.    if(this.left!=null){  
  33.      this.left.printNode();  
  34.  }  
  35.   System.out.print(this.data+"\t");  
  36.    if(this.right!=null){  
  37.      this.right.printNode();  
  38.  }  
  39.  
  40.  }  
  41.  };  
  42.  private Node root;  
  43.  public void add(Comparable data){  
  44.     Node newNode=new Node();  
  45.  
  46.     newNode.data=data;  
  47.  if(root==null){  
  48.  root=newNode;  
  49.  }else{  
  50.  root.addNode(newNode);  
  51.  }  
  52.  }  
  53.  public void print(){  
  54.  this.root.printNode();  
  55.  }  
  56.  };  
  57.  public class ComparableDemo{  
  58.  public static void main(String[] args){  
  59.  BinaryTree bt=new BinaryTree();  
  60.  bt.add(9);  
  61.  bt.add(8);  
  62.  bt.add(10);  
  63.  bt.add(3);  
  64.  bt.add(2);  
  65.  bt.add(4);  
  66.  bt.add(5);  
  67.  bt.add(7);  
  68.  System.out.println("The sorted result is: ");  
  69.  bt.print();  
  70.  }  
  71.  }  

此Comparable接口在本机测试通过,结果为:
The sorted result is:
2 3 4 5 7 8 9 10

本文来自jimyChen的博客:《Comparable接口》

名称栏目:教你使用Comparable接口
网站地址:http://www.gawzjz.com/qtweb2/news29/10929.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联