TreeSet() 类逆向排序(实现compare()方法以便按正常顺序的逆向进行操作)。

原创 2006年06月14日 10:28:00

/*

仔细观察实现Comparator并覆盖compare()方法的MyComp类(覆盖equals方法既不是必须的,也不是常用的)。在compare()方法内部,String方法compareTo()比较两个字符串。然而由strB-----不是strA------调用compareTo()方法,这导致比较的结果被逆向。

*/

//Use a custom comparator
import java.util.*;
//A reverse comparator for strings.
class  MyComp implements Comparator{
 public int compare(Object a,Object b){
  String strA,strB;
  strA = (String)a;
  strB = (String)b;

  //reverse the comparison
  return strB.compareTo(strA);
 }
 //no need to override equals
}
public class CompDemo{
 public static void main(String[] args)
 {
  //Create a tree set.
  TreeSet ts = new TreeSet(new MyComp());

  //Ade elements to the tree set
  ts.add("C");
  ts.add("F");
  ts.add("A");
  ts.add("B");
  ts.add("D");

  //Get an iterator
  Iterator i = ts.iterator();

  //Display elements
  while(i.hasNext()){
   Object element = i.next();
   System.out.println(element + " ");
  }
  System.out.println();
 }
}

相关文章推荐

Java编程之TreeSet排序两种解决方法(1)元素自身具备比较功能,元素需要实现Comparable接口覆盖compare(2)创建根据自定义Person类的name进行排序的Comparator

TreeSet还具有可以对集合中的元素进行指定顺序的排序的功能。 这个功能实现的基本原理就是,当存放元素的时候进行比较,比较之后再存入。对于普通的字符串它可以完美的实现排序功能,但当是自定义类的时候就...

set集合 HashSet: TreeSet实现Comparable接口,覆盖compareTo方法。 类实现Comparator接口,覆盖compare方法。

Set:元素是无序的(存入和取出的顺序不一定一致),   |--   |--   |--

利用TreeSet进行排序操作

package list; import java.util.*; public class TreeSetTest { public static void main(String[...
  • tdy002
  • tdy002
  • 2012年05月07日 13:58
  • 305

在TreeSet中实现存储自定义对象,并且能够按照特定的顺序排序

package cn.itcast.demo; import java.util.*; class Person implements Comparable { private String na...

TreeSet是可以对字符串进行排序 的, 因为字符串已经实现了Comparable接口。

package cn.itcastset;import java.util.TreeSet; /* TreeSet是可以对字符串进行排序 的, 因为字符串已经实现了Comparable接 口。字符串的...

TreeSet对元素进行排序实现的两种方式

package interview; import java.util.Comparator; import java.util.Iterator; import java.util.T...

往TreeSet中存入自定义对象,并且使用自定义排序方法(实现comparetor)

import java.util.*; class Person implements Comparable { private String name; private int age; Pe...

java自学笔记————对于TreeSet实现排序的两种方法;

Set:无序,不可以重复元素。常用的子类,  HashSet:数据结构是哈希表。线程是非同步的。     保证元素唯一性的原理:判断元素的hashCode值是否相同。     如果相同,还会继续判断元...

My_Java之笔记(8)- 实现TreeSet集合的排序方法

方法一:元素实现Comparable接口,重写compareTo()方法,实现集合排序 方法二:定义一个比较器传给TreeSet的构造函数,该比较器实现Comparator接口,重写compare(...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:TreeSet() 类逆向排序(实现compare()方法以便按正常顺序的逆向进行操作)。
举报原因:
原因补充:

(最多只允许输入30个字)