• 3. List


    数据结构在Java集合中的对应关系

    线性表【数组】 -> ArrayList
    线性表【链表】-> LinkedList
    队列 -> Queue -> LinkedList,PriorityQueue, ArrayBlockingQueue … etc.
    双端队列 -> Deque -> ArrayDeque
    栈 -> LinkedList
    哈希表 -> HashSet, HashTable, HashMap
    跳表 -> ConcurrentSkipListMap
    二叉树[red-black tree] -> treeMap, treeSet
    哈希表 + 链表 -> LinkedHashMap, LinkedHashSet

    List即数据结构中最基本的线性表,有数组和链表两种实现。 它的基本特征: 有序,可重复,除了第一个和最后一个元素,每个元素都只有一个前驱和一个后继。

    Java 集合API中使用List接口来抽象化线性表,提供针对集合的CURD操作,相比Collection接口,List可以支持按索引位插入和查找,尤其当实现类是ArrayList时,可实现按下标的随机查找。

    List接口方法

    在Collection的基础上,新增如下方法:
    1)E get(int index)
    返回指定索引位上的值,如果底层是数组,可以随机访问,时间复杂度O(1), 如果是链表,不支持随机访问,时间复杂度是O(n)。

    2) E set(int index, E element)
    相当于replace, 即更新指定索引位置上的元素

    3) void add(int index, E element)
    在指定索引位上插入元素,底层是数组时如果该索引位不是size(),则会涉及到移位,此时时间复杂度是O(n), 而底层是链表时,比较简单,时间复杂度时O(1)

    4) E remove(int index)
    移除指定索引位的值

    5) indexOf(Object o)
    从前往后查找指定元素的索引位,找不到时为-1, 使用equals判断元素是否相等

    6) lastIndexOf(Object o)
    从后往前查找指定元素的索引位,找不到时为-1

    7) ListIterator listIterator()
    返回增强的Iterator,它在基本的iterator基础上,新增了CUD功能,还能向前遍历。

    8) List of(E e1, E e2 …)
    比较实用的方法,能基于给定的元素生成unmodifiable list

  • 相关阅读:
    python--函数
    图片怎么压缩到100k以下?
    基于Selenium+Python的web自动化测试框架
    Kotlin中的委托、属性委托和延迟加载
    MySQL不常用查询
    mysql主从复制与读写分离
    java-net-php-python-JSP学校教育论坛管理系统开题任务书PPT计算机毕业设计程序
    (C语言)P1002 [NOIP2002 普及组] 过河卒
    《Windows 核心编程》27章:硬件输入模型和局部输入状态
    【经验】提升Android Studio构建速度
  • 原文地址:https://blog.csdn.net/qq_25027457/article/details/134251641