1、TreeSe自带排序的set,没有重复元素。

2、TreeSet 如果构造函数中没有使用比较器,那在装载的对象类中要实现Comparable 接口。

3、TreeSet 使用初始化比较器的方式。

试例代码:

public class Demo {

public static void main(String[] args) {

//1、TreeSe自带排序的set,没有重复元素

TreeSet<String> setStr=new TreeSet<String>();

setStr.add("E");

setStr.add("D");

setStr.add("C");

setStr.add("A");

setStr.add("B");

setStr.add("B");

System.out.println(setStr.toString());

System.out.println("-------------遍历方式:1、使用迭代器遍历------------");

Iterator<String> ite = setStr.iterator();

while(ite.hasNext()) {

System.out.println(ite.next());

}

System.out.println("-------------遍历方式:2、使用数组遍历------------");

Object[] objs = setStr.toArray();

for(int i=0;i<objs.length;i++) {

System.out.println(objs[i]);

}

//2、TreeSet 如果构造函数中没有使用比较器,那在装载的对象类中要实现Comparable 接口

System.out.println("-------------TreeSet 如果构造函数中没有使用比较器,那在装载的对象类中要实现Comparable 接口------------");

TreeSet<person> setPerson=new TreeSet<person>();

setPerson.add(new person("张三",20));

setPerson.add(new person("李四",19));

setPerson.add(new person("王五",32));

System.out.println(setPerson.toString());

//3、TreeSet 使用初始化比较器的方式

System.out.println("-------------TreeSet在初始化时使用构造器------------");

TreeSet<book> set=new TreeSet<book>(new BookComparator());

set.add(new book("流浪地球",100));

set.add(new book("三体",90));

set.add(new book("大秦帝国",110));

System.out.println(set.toString());

System.out.println("-------------遍历方式:1、使用迭代器遍历------------");

Iterator<book> iteBook = set.iterator();

while(iteBook.hasNext()) {

System.out.println(iteBook.next());

}

System.out.println("-------------遍历方式:2、使用数组遍历------------");

Object[] objsBook = set.toArray();

for(int i=0;i<objsBook.length;i++) {

System.out.println(objsBook[i]);

}

System.out.println("-------------遍历方式:3、使用foreach方式------------");
  for(book b :set) {
   System.out.println(b);
  }

} }

class person implements Comparable<person>{

String name;  int age;

person(String name,int age){

this.name=name;   this.age=age;

}

@Override

public String toString() {

return "姓名:"+this.name+" 年龄:"+this.age;

}

@Override

public int compareTo(person o) {

if(o.age>this.age) {

return 1;

} else if(o.age<this.age) {

return -1;

}

return 0;

} }

class book {

String name;  double price;

book(String name,double price){

this.name=name;   this.price=price;

}

@Override

public String toString() {

return "书名:"+this.name+" 价格:"+this.price;

}  }

class BookComparator implements Comparator<book>{

@Override

public int compare(book o1, book o2) {

if(o1.price>o2.price) {

return 1;

} else if(o1.price < o2.price){

return -1;

}   return 0;

}

}

Java TreeSet的使用的更多相关文章

  1. Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序

    package TreeSetTest; import java.util.Iterator; import java.util.TreeSet; import javax.management.Ru ...

  2. java TreeSet 应用

    本文主要是介绍一下java集合中的比较重要的Set接口下的可实现类TreeSet TreeSet类,底层用二叉树的数据结构 * 集合中以有序的方式插入和抽取元素. * 添加到TreeSet中的元素必须 ...

  3. Java TreeSet的定制排序

    注:只贴出实现类 package Test3; import java.util.Comparator;import java.util.TreeSet; public class Test { pu ...

  4. Java - TreeSet源码解析

    Java提高篇(二八)------TreeSet 与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.在<Java提高篇(二七)-----TreeMap& ...

  5. java TreeSet 实现存自定义不可重复数据

    本文主要是介绍一下java集合中的比较重要的Set接口下的可实现类TreeSet TreeSet类,底层用二叉树的数据结构 * 集合中以有序的方式插入和抽取元素. * 添加到TreeSet中的元素必须 ...

  6. 【Todo】Java TreeSet学习 & ceiling,floor

    参考 http://www.yiibai.com/java/util/java_util_treeset.html 另,用Java的TreeSet的ceiling可以模拟upper_bound(获得更 ...

  7. java TreeSet的排序之定制排序

    TreeSet的自然排序是根据元素的大小进行升序排序的,若想自己定制排序,比如降序排序,就可以使用Comparator接口了: 该接口包含int compare(Object o1,Object o2 ...

  8. java TreeSet的排序之自然排序

    TreeSet会调用元素的compareTo(Object o)方法来比较元素之间的大小关系,然后将集合里的元素按升序排列.此时需要排序元素的类必须实现Compareble接口,并覆写其int com ...

  9. Java TreeSet集合 比较器排序Comparator的使用

    比较器排序Comparator的使用 存储学生对象,并遍历,创建TreeSet集合使用带参构造方法 要求,按照学生年龄从小到大排序,如果年龄相同,则按照姓名的字母循序排序 结论 用TreeSet集合存 ...

  10. java TreeSet应用

    这篇是紧接着上一篇而写的,具体的实现TreeSet中有序的第二中方法 首先新建一个类,此类就是用于集合中存放的对象 然后定义一个类,实现Comparator中的CompareTo()方法 最后一个测试 ...

随机推荐

  1. 快速回顾MySQL:汇总和分组

    10.3 汇总数据 我们经常需要汇总数据而不用把它们实际检索处出来,为此MySQL提供了专门的函数.使用这些函数,MySQL查询可用于检索数据,以便分析和报表的生成.这种类型的检索例子有以下几种: 确 ...

  2. android:整理drawable(余下的)(三)

    前言 随着bitmapDrawabe.nithpatchDrawable 与 shapeDrawable 的整理,接下的就更加需要自己的想象设计一些东西. LayerDrawable 意思是层级性的, ...

  3. Java框架之MyBatis 07-动态SQL-缓存机制-逆向工程-分页插件

    MyBatis 今天大年初一,你在学习!不学习做什么,斗地主...人都凑不齐.学习吧,学习使我快乐!除了诗和远方还有责任,我也想担当,我也想负责,可臣妾做不到啊,怎么办?你说怎么办,为啥人家能做到你做 ...

  4. 第二阶段冲刺个人任务——three

    今日任务: 优化统计个人博客结果页面的显示. 昨日成果: 优化作业查询结果,按学号排列.

  5. 基于python的感知机

    一. 1.感知机可以描述为一个线性方程,用python的伪代码可表示为: sum(weight_i * x_i) + bias -> activation #activation表示激活函数,x ...

  6. Shell命令整理

    Shell命令 一.认识Shell 在Linux系统中,Shell充当着用户与Linux内核的桥梁,俗称壳保护着Linux内核,同时也负责完成用户与内核之间的交互. 当用户需要与内核交互时,将命令传递 ...

  7. 使用typescript改造koa开发框架

    强类型的 TypeScript 开发体验和维护项目上相比 JavaScript 有着明显的优势,那么对常用的脚手架进行改造也就势在必行了. 接下来开始对基于 koa 框架的 node 后端脚手架进行改 ...

  8. springIOC源码接口分析(二):ConfigurableBeanFactory

    一 继承功能 1 SingletonBeanRegistry接口 此接口是针对Spring中的单例Bean设计的.提供了统一访问单例Bean的功能,类中定义了以下方法: 2 HierarchicalB ...

  9. linux下oracle调试小知识

    1.oracle 安装下的/u01/diag/rdbms/orcl/HOF/incident目录下是什么文件?答:每当一个错误发生的时候,oracle会创建一个incident,并且分配一个INCID ...

  10. Word Embeddings: Encoding Lexical Semantics(译文)

    词向量:编码词汇级别的信息 url:http://pytorch.org/tutorials/beginner/nlp/word_embeddings_tutorial.html?highlight= ...