java基础总结(面试高频问题)十二:Java的集合类,数组去除重复数据的方法

1:直观框架图:
旧版:
在这里插入图片描述

新版:
在这里插入图片描述

java的集合类主要包括两种类型的容器,一种是集合(Collection),另一种是映射(Map);
Collection接口又有3种子类型,List、Set和Queue,再下面是一些抽象类,最后是具体实现类,常用的有ArrayList、LinkedList、HashSet、LinkedHashSet等等;
Map常用的有HashMap,LinkedHashMap等。

2:List总结:
List是有序的,可重复的,通过索引取出和加入数据;顺序和插入顺序一致,可以含有null元素;
List接口有两个重要的具体实现类,也是我们可能最常用的类,ArrayList和LinkedList;另外还有一个Vector类;
(1)ArrayList:底层数据结构使用数组结构array,查询速度快,增删改慢,因为是一种类似数组的形式进行存储,因此它的随机访问速度极快;
(2)LinkedList:底层使用链表结构,增删速度快,查询稍慢;
(3)Vector:底层是数组结构array,与ArrayList相同,查询速度快,增删改慢;
(4)ArrayList和Vector的区别:
<1>如果集合中的元素数量大于当前集合数组的长度时,Vector的增长率是目前数组长度的100%,而ArryaList增长率为目前数组长度的50%。所以,如果集合中使用数据量比较大的数据,用Vector有一定优势;
<2>ArrayList是线程不安全的,Vector是线程安全的,但是因为Vector的每个方法都加上了synchronized关键字,所以在效率上小于ArrayList;

3:Set总结(所有实现类均不是线程安全的类):
set的实例不包含重复的元素,在一个规定集合内,一定不存在两个相同的元素;Set接口有三个具体实现类,分别是散列集HashSet、链式散列集LinkedHashSet和树形集TreeSet;
(1)HashSet:是Set接口(Set接口是继承了Collection接口的)最常用的实现类,底层是用了哈希表(散列/hash)算法。其底层其实也是一个数组,存在的意义是提升查询速度,插入的速度也比较快,但是适用于少量数据的插入操作;
判断两个对象是否相等的规则:1、equals比较为true;2、hashCode值相同。要求:要求存在在哈希表中的对象元素都得覆盖equals和hashCode方法。
(2)LinkedHashSet:继承了HashSet类,所以它的底层用的也是哈希表的数据结构,因为需要保持数据的先后添加顺序,所以又加了链表结构,但因为多加了一种数据结构,所以效率较低,不建议使用,如果要求一个集合保证元素不重复,也需要记录元素的先后添加顺序,才选择使用LinkedHashSet;
(3)TreeSet:Set接口的实现类,也拥有set接口的一般特性,但是不同的是他也实现了SortSet接口,它底层采用的是红黑树算法(红黑树就是满足一下红黑性质的二叉搜索树:①每个节点是黑色或者红色②根节点是黑色的③每个叶子结点是黑色的④如果一个节点是红色的,那么他的两个子节点是黑色的⑤对每个节点,从该节点到其所有的后代叶子结点的简单路径上,仅包含相同数目的黑色结点,红黑树是许多“平衡”搜索树的一种,可以保证在最坏情况下的基本操作集合的时间复杂度为O(lgn)。
普及:二叉搜索树的性质:它或者是一棵空树;或者是具有下列性质的二叉树:若左子树不空,则左子树上所有结点的值均小于它的根结点的值;若右子树不空,则右子树上所有结点的值均大于它的根结点的值;左、右子树也分别为二叉排序树。若子树为空,查找不成功。),要注意的是在TreeSet集合中只能存储相同类型对象的引用。
Tree最重要的就是它的两种排序方式:自然排序和客户端排序
<1>自然排序;实现了Comparable接口,所以TreeSet可以调用对象的ComparableTo()方法来比较集合的大小,然后进行升序排序,这种排序方式叫做自然排序。其中实现了Comparable接口的还有BigDecimal、BigInteger、Byte、Double、Float、Integer、Long、Short(按照数字大小排序)、Character(按照Unicode值的数字大小进行排序)String(按照字符串中字符的Unicode值进行排序)类等;
<2>客户化排序:其实就是实现java.util.Comparator接口提供的具体的排序方式, 是具体要比较对象的类型,他有个compare的方法,如compare(x,y)返回值大于0表示x大于y,以此类推,当我们希望按照自己的想法排序的时候可以重写compare方法;

4:Map总结:
java的Map(映射)是一种把键对象和值对象进行映射的集合,其中每一个元素都包含了键对象和值对象,其中值对象也可以是Map类型的数据,因此,Map支持多级映射,Map中的键是唯一的,但值可以不唯一,Map集合有两种实现,一种是利用哈希表来完成的叫做HashMap,它和HashSet都是利用哈希表来完成的,区别其实就是在哈希表的每个桶中,HashSet只有key,而HashMap在每个key上挂了一个value;另一种就是TreeMap,它实现了SortMap接口,也就是使用了红黑树的数据结构,和TreeSet一样也能实现自然排序和客户化排序两种排序方式,而哈希表不提供排序;

(1)HashMap:详见0-4节;

(2)TreeMap:TreeMap 是一个有序的key-value集合,它是通过红黑树实现的。TreeMap 继承于AbstractMap,所以它是一个Map,即一个key-value集合;
TreeMap 实现了NavigableMap接口,意味着它支持一系列的导航方法。比如返回有序的key集合;
TreeMap 实现了Cloneable接口,意味着它能被克隆;
TreeMap 实现了java.io.Serializable接口,意味着它支持序列化;
TreeMap基于红黑树(Red-Black tree)实现。该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序,具体取决于使用的构造方法;
TreeMap的基本操作 containsKey、get、put 和 remove 的时间复杂度是 log(n) ;
另外,TreeMap是非同步的,不安全。 它的iterator 方法返回的迭代器是fail-fastl的;

(3)HashTable:Hashtable继承Map接口,实现一个key-value映射的哈希表。任何非空(non-null)的对象都可作为key或者value,线程安全;

5:数组去除重复数据的方法

(1)用List集合实现:list.contains(str[i])方法为判断前面数据中是否包含str[i],若包含,返回true,不包含,返回false
在这里插入图片描述

输出:
在这里插入图片描述

(2)用hashSet或者TreeSet实现
在这里插入图片描述

输出:
在这里插入图片描述

其中Arrays.asList()是将一个数组转化为一个List对象,这个方法会返回一个ArrayList类型的对象, 这个ArrayList类并非java.util.ArrayList类,而是Arrays类的静态内部类!
TreeSet不仅可以使元素不重复,而且可以实现排序等功能的集合,它在对象元素添加到集合中时会自动按照某种比较规则将其插入到有序的对象序列中。

(3)用List和set(集合)实现
在这里插入图片描述

输出:
在这里插入图片描述

不仅删除了重复元素,还进行了排序;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值