ArrayList效率分析与LinkedList性能对比

一、ArrayList

1.数据结构

数组 -> 顺序表。

2.插入数据

在数组中间插入数据,其后的数据都会往后copy,时间复杂度为O(n)。

3.删除数据

与插入类似,同样涉及数据的copy,时间复杂度为O(n)。

4.查找元素

通过下标查找元素,非常快,时间复杂度为O(1)。

二、LinkedList

1.数据结构

链表。

2.插入数据

指定位置上断开链表,插入新元素,重新连接成链表,时间复杂度为O(1)。

3.删除元素

指定位置上断开链表,删除元素,重新连接成链表,时间复杂度为O(1)。

4.查找元素

遍历链表查找指定元素,时间复杂度为O(n)。

三、对比

插入和删除效率,LinkedList更快。

查找效率,ArrayList更快。

四、思考

1.如果一个数组要反复插入删除,怎么优化降低时间复杂度?

当删除元素时,并不是真正删除元素,而是将删除的位置标记为null或其他标记,当内部不足时,使用for循环遍历数据,删除被标记为null的元素。(JVM使用到的标记-删除算法)

相关推荐
OtIo TALL15 小时前
redis7 for windows的安装教程
java
Sam_Deep_Thinking15 小时前
学数据结构到底有什么用
数据结构
uNke DEPH15 小时前
Spring Boot的项目结构
java·spring boot·后端
xixingzhe215 小时前
idea启动vue项目
java·vue.js·intellij-idea
wzl2026121316 小时前
企业微信定时群发技术实现与实操指南(原生接口+工具落地)
java·运维·前端·企业微信
凌波粒16 小时前
Java 8 “新”特性详解:Lambda、函数式接口、Stream、Optional 与方法引用
java·开发语言·idea
曹牧16 小时前
Eclipse:悬停提示(Hover)
java·ide·eclipse
oyzz12016 小时前
Spring EL 表达式的简单介绍和使用
java·后端·spring
iNgs IMAC17 小时前
Redis之Redis事务
java·数据库·redis
程序员小假17 小时前
向量检索的流程是怎样的?Embedding 和 Rerank 各自的作用?
java·后端