当前位置: 首页 > news >正文

Java List Set Map

一、List 

1.1 ArrayList

1.2 LinkedList

二、Set

2.1 HashSet

2.2 TreeSet

2.3 LinkedHashSet

 

三、Map

3.1 HashMap

3.2 TreeMap

3.3 LinkedHashMap

四、对比

类型底层结构重复null值场景备注查询删除新增
ListArrayList动态数组允许快速随机访问元素0(1)0(n)尾部增加0(1),中部增加0(n)
LinkList双向链表允许需要快速插入,删除元素0(n)0(1)尾部增加0(1),中部增加0(n)
SetHashSet数组+(链表、红黑树)不可允许不要求顺序,且没有重复元素重写hsahCode、equlas0(1)0(1)0(1)
TreeSet红黑树不可不允许要求顺序,且没有重复元素重写comparato0(logN)0(logN)0(logN)
LinkedHashSet数组+(链表、红黑树))+链表不可允许有特定输出顺序,且没有重复元素0(1)0(1)0(1)
MapHashMap数组+(链表、红黑树)不可允许键值存取,而且不要求顺序时间复杂度平均能达到O(1)。正常是O(1)到O(n) jdk1.8添加了 红黑树 是 O(log n)0(1)0(1)0(1)
TreeMap红黑树不可不允许键值存取值,而且要求顺序重写comparato0(logN)0(logN)0(logN)
LinkedHashMap(数组+(链表、红黑树))+链表不可允许有特定输出顺序键,键值存取0(1)0(1)0(1)
http://www.lryc.cn/news/213148.html

相关文章:

  • 【数据结构】数组和字符串(十三):链式字符串的基本操作(串长统计、查找、复制、插入、删除、串拼接)
  • Python3 获取当前服务器公网 IP 地址
  • EAS查前5分钟到现在的组织变动数据
  • uni-app——如何阻止事件冒泡
  • [MySQL]索引
  • 什么是AUTOSAR ComStack,AUTOSAR架构中,CAN通信堆栈CAN Communication Stack介绍
  • 黄金期货与黄金现货的区别
  • 【数据结构】数组和字符串(五):特殊矩阵的压缩存储:稀疏矩阵——压缩稀疏行(CSR)
  • springboot整合postgresql
  • C#__委托delegate
  • Jupyter Notebook的安装方法以及生成ipykernel
  • 测试员如何快速复现bug?一款合适的视频录制软件了解一下
  • 论文-分布式-并发控制-并发控制问题的解决方案
  • 【网络协议】聊聊http协议
  • 图神经网络论文笔记(一)——北邮:基于学习解纠缠因果子结构的图神经网络去偏
  • java初始化list的几种方式
  • Linux:文件操作
  • vue源码笔记之——运行时runtime
  • MySQL数据库干货_09—— MySQL中的外键约束(Foreign Key)
  • springboot配置https
  • java - IDEA IDE - 设置字符串断点
  • 【图像分类】基于计算机视觉的坑洼道路检测和识别(ResNet网络,附代码和数据集)
  • 关于readline方法使用的一个中文乱码引发的思考
  • BUUCTF 神秘龙卷风 1
  • 【JavaEE初阶】 认识文件与Java中操作文件
  • 数据结构───链表
  • SQLAlchemy删除所有重复的用户|Counter类运用
  • Lec11 Thread switching (Robert)
  • 前端的简单介绍
  • 云服务器 centos 部署 code-server 并配置 c/c++ 环境