Set的常用实现类HashSet和TreeSet
Set HashSet
public static void main(String[] args) {
//不可以重复 并且是无序的
//自然排序 从A-Z
//eqauls从Object继承,默认比较地址
// Set<String> set= new HashSet<>();
// set.add("zs");
// set.add("ls");
// set.add("ww");
// set.add("qq");
// set.add("zs");
// System.out.println(set.size());
// //遍历
//迭代器
// Iterator<String > it= set.iterator();
// while(it.hasNext()) {
// System.out.println(it.next());
// }
// System.out.println("-------------------");
// //Foreach
// for(String s: set) {
// System.out.println(s);
// }
//常用实现类 HashSet
Set<Person> s= new HashSet<>();
//System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
//System.out.println(new Person(1,"zs",18));
s.add(new Person(1,"zs",18));
s.add(new Person(2,"ls",18));
s.add(new Person(3,"ww",18));
s.add(new Person(4,"zl",18));
s.add(new Person(5,"qq",18));
//foreach的底层原理就是迭代器
for(Person p:s) {
//默认转换为String的数据类型
System.out.println(p);
}
}
TreeSet
public static void main(String[] args) {
//常用实现类 TreeSet :根据某种(规则)对里面的元素进行排序
//规则1 :java.lang.Comparable
//规则2 :java.util.Comparator
// Set<String> set= new TreeSet<>();
// set.add("zs");
// set.add("ls");
// set.add("ww");
// set.add("qq");
// set.add("zs");
// System.out.println(set.size());
//
遍历
迭代器
// Iterator<String > it= set.iterator();
// while(it.hasNext()) {
// System.out.println(it.next());
// }
// System.out.println("-------------------");
// Foreach
// for(String s: set) {
// System.out.println(s);
// }
//自然排序器
// Set<Person> s= new TreeSet<>();
// //System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
// //System.out.println(new Person(1,"zs",18));
// s.add(new Person(1,"zs",18));
// s.add(new Person(2,"ls",18));
// s.add(new Person(3,"ww",18));
// s.add(new Person(4,"zl",18));
// s.add(new Person(5,"qq",18));
//
// //foreach的底层原理就是迭代器
// for(Person p:s) {
// //默认转换为String的数据类型
// System.out.println(p);
// }
// 自定义的排序器(根据年龄排序)
Set<Person> s= new TreeSet<>(new Age());
//System.out.println(new Person(1,"ls",18).equals(new Person(1,"zs",18)));
//System.out.println(new Person(1,"zs",18));
s.add(new Person(1,"zs",18));
s.add(new Person(2,"ls",19));
s.add(new Person(3,"ww",80));
s.add(new Person(4,"zl",30));
s.add(new Person(5,"qq",20));
for(Person p:s) {
System.out.println(p);
}
}
Set的常用实现类HashSet和TreeSet的更多相关文章
- Java 基础 - Set接口 及其实现类HashSet/LinkedHashSet/TreeSet
笔记: /**Set接口 及其实现类 * 公用操作同Collection: * * ①size(),clear()②isEmpty(),③contains(),④add()方法 和remove()方法 ...
- Java开发笔记(六十五)集合:HashSet和TreeSet
对于相同类型的一组数据,虽然Java已经提供了数组加以表达,但是数组的结构实在太简单了,第一它无法直接添加新元素,第二它只能按照线性排列,故而数组用于基本的操作倒还凑合,若要用于复杂的处理就无法胜任了 ...
- HashSet,TreeSet和LinkedHashSet的区别
1. Set接口 Set不允许包含相同的元素,如果试图把两个相同元素加入同一个集合中,add方法返回false. Set判断两个对象相同不是使用==运算符,而是根据equals方法.也就是说,只要两个 ...
- 算法竞赛中的常用JAVA API :HashSet 和 TreeSet(转载)
算法竞赛中的常用JAVA API :HashSet 和 TreeSet set set容器的特点是不包含重复元素,也就是说自动去重. HashSet HashSet基于哈希表实现,无序. add(E ...
- Java集合框架之四大接口、常用实现类
Java集合框架 <Java集合框架的四大接口> Collection:存储无序的.不唯一的数据:其下有List和Set两大接口. List:存储有序的.不唯一的数据: Set:存储无序的 ...
- 30、Java中Set集合之HashSet、TreeSet和EnumSet
Set集合是Collection的子集,Set集合与Collection基本相同,没有提供任何额外的方法,只是Set不允许包含重复的元素. Set集合3个实现类:HashSet.TreeSet.Enu ...
- Map接口常用实现类学习
HashMap 1.6的HashMap:数组加单向链表结构 最重要的内部类Entry,全类名是java.util.HashMap.Entry,是个静态类,实现了Map.Entry接口.HashMap. ...
- Java集合详解7:一文搞清楚HashSet,TreeSet与LinkedHashSet的异同
<Java集合详解系列>是我在完成夯实Java基础篇的系列博客后准备开始写的新系列. 这些文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查 ...
- List接口和Set接口及其常用实现类概述
一.List接口 List:有序的 collection(也称为序列).此接口的用户可以对列表中每个元素的插入位置进行精确地控制.用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元 ...
随机推荐
- 深入Java中的位操作
「WTF系列」深入Java中的位操作 关于WTF系列 引 学完本章节你将学会位的基础概念与语法,并且还会一些骚操作!! 与.或.非.位移 原码.反码.补码 字节.位.超区间...... 开始本章节之前 ...
- logrus 剖析之滚动日志
在实际开发过程中,为了节省磁盘,日志需要按照时间或者大小维度进行切割分成多分,归档过期的日志,删除久远的日志.这个就是在日常开发中经常遇见的日志滚动(log rotation) 那么在 logrus ...
- SAS学习笔记59 OPTIONS系统选项
带VALUE选项的OPTIONS过程将指定选项的值.范围及该值如何设置的信息打印到日志窗口 在日志窗口打印的输出如下图所示 将GETOPTION函数作为%SYSFUNC宏函数的参数,从而获取系统选项设 ...
- 百度云服务接口错误:Parameter invalid, the key input with filter parameter is not searchfilter column key
百度LBS云服务接口: 地址:http://lbsyun.baidu.com/index.php?title=lbscloud/api/geosearch 访问接口:http://api.map.ba ...
- 【题解】Luogu P4910 帕秋莉的手环
原题传送门 "连续的两个中至少有1个金的"珂以理解为"不能有两个木相连" 我们考虑一个一个将元素加入手环 设f\([i][0/1]\)表示长度为\(i\)手环末 ...
- go 读取BMP文件头二进制读取
BMP文件头定义: WORD 两个字节 16bit DWORD 四个字节 32bit package main import ( "encoding/binary" "f ...
- [高清·非影印] Docker 容器与容器云(第2版)
------ 郑重声明 --------- 资源来自网络,纯粹共享交流, 如果喜欢,请您务必支持正版!! --------------------------------------------- 下 ...
- 系統启动直接进BIOS
- ssh免秘钥
用过好几次免秘钥,但是每次都会忘了应该把copy谁的公钥到另外用户的.ssh文件夹 这里专门记录一次 注意点: A要使用ssh免密登录到B用户下(可以使远程服务器),就把A的用户下的.ssh文件的id ...
- 【洛谷 P1659】 [国家集训队]拉拉队排练(manacher)
题目链接 马拉车+简单膜你 #include <cstdio> #include <cstring> #include <algorithm> using name ...