Java TreeSet的使用
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的使用的更多相关文章
- Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序
package TreeSetTest; import java.util.Iterator; import java.util.TreeSet; import javax.management.Ru ...
- java TreeSet 应用
本文主要是介绍一下java集合中的比较重要的Set接口下的可实现类TreeSet TreeSet类,底层用二叉树的数据结构 * 集合中以有序的方式插入和抽取元素. * 添加到TreeSet中的元素必须 ...
- Java TreeSet的定制排序
注:只贴出实现类 package Test3; import java.util.Comparator;import java.util.TreeSet; public class Test { pu ...
- Java - TreeSet源码解析
Java提高篇(二八)------TreeSet 与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.在<Java提高篇(二七)-----TreeMap& ...
- java TreeSet 实现存自定义不可重复数据
本文主要是介绍一下java集合中的比较重要的Set接口下的可实现类TreeSet TreeSet类,底层用二叉树的数据结构 * 集合中以有序的方式插入和抽取元素. * 添加到TreeSet中的元素必须 ...
- 【Todo】Java TreeSet学习 & ceiling,floor
参考 http://www.yiibai.com/java/util/java_util_treeset.html 另,用Java的TreeSet的ceiling可以模拟upper_bound(获得更 ...
- java TreeSet的排序之定制排序
TreeSet的自然排序是根据元素的大小进行升序排序的,若想自己定制排序,比如降序排序,就可以使用Comparator接口了: 该接口包含int compare(Object o1,Object o2 ...
- java TreeSet的排序之自然排序
TreeSet会调用元素的compareTo(Object o)方法来比较元素之间的大小关系,然后将集合里的元素按升序排列.此时需要排序元素的类必须实现Compareble接口,并覆写其int com ...
- Java TreeSet集合 比较器排序Comparator的使用
比较器排序Comparator的使用 存储学生对象,并遍历,创建TreeSet集合使用带参构造方法 要求,按照学生年龄从小到大排序,如果年龄相同,则按照姓名的字母循序排序 结论 用TreeSet集合存 ...
- java TreeSet应用
这篇是紧接着上一篇而写的,具体的实现TreeSet中有序的第二中方法 首先新建一个类,此类就是用于集合中存放的对象 然后定义一个类,实现Comparator中的CompareTo()方法 最后一个测试 ...
随机推荐
- axios中请求传值方式
日常开发中与后端联调,可能需要的数据不同,所传值也有所不同 1.如果是data方式,设置请求头为:并且直接返回data就可以 raw axios.defaults.headers['Content- ...
- 【PCIE-3】---PCIE设备的枚举扫描(经典好文)
前面两个小节大致总结了下PCIE的基本知识,算是扫盲篇吧.本文主要总结PCIE设备的枚举扫描过程,此部分才是PCIE模块的重点,无论是在BIOS下还是系统驱动下都会用到. 按照国际惯例,先列问题: 1 ...
- 打包一份py给大家用!!!
好不容易写完了代码,却发现对面无法使用自己的python代码,其无奈可想而知 在这里就给大家介绍一下pyinstaller的简单用法 你所需要的就是在电脑上安装好 https://blog.csdn. ...
- requests请求
requests:伪造浏览器请求 请求 1.get requests.get( url='', params={ 'k1': ''v1, 'k2': 'v2' } ) 即 url?k1=k2& ...
- 洛谷P3335 [ZJOI2013]蚂蚁寻路
题目描述 在一个 n*m 的棋盘上,每个格子有一个权值,初始时,在某个格子的顶点处一只面朝北的蚂蚁,我们只知道它的行走路线是如何转弯,却不知道每次转弯前走了多长. 蚂蚁转弯是有一定特点的,即它的转弯序 ...
- Windows版Redis主从配置
一.下载 从github上下载Redis的zip包,地址:https://github.com/MicrosoftArchive/redis/releases Redis本身不支持windows,这是 ...
- python之路:day2
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- vue 新建脚手架项目npm命令
使用国外原镜像 npm install -g @vue/cli //yarn global add @vue/cli 使用淘宝镜像 cnpm install -g @vue/ ...
- 并发队列之LinkedBlockingQueue
上一篇我们看了一下这个队列ConcurrentLinkedQueue,那就是一个无界非阻塞链表,我们这次来看看LinkedBlockingQueue,这个队列看名字就知道是一个阻塞式队列(也就是一个单 ...
- 使用alpine制作最小化的JDK基础镜像
注意:这里使用的是oracle的JRE,版本是1.8. 1.解压jre包,删除根目录下文本文件,然后删除其他不必要文件. #解压 tar xvcf jre-8u161-linux-x64.tar.gz ...