八股复习2:Java Array list和Linked list

又是我们经典的数据结构!!

虽然它们都是list,但是内部的结构不同:

------------------------------------------------Arraylist ------------------------------------------------------------------

Arraylist是序号数组,每一个元素都有一个自己的index,也就是索引

嗨嗨嗨!看到这个索引你就知道了!Arraylist查询很快!!!

但是缺点就是修改不是很方便,这个数据结构修改的特点是牵一发而动全身的:

比如删除一个元素,需要移动整个元素来补齐刚刚空缺的位置,就像是体育课有一列空了一位同学,那么这一列后面的同学就来补齐整个列队一样

Arraylist操作中间的元素比较麻烦,那么头和尾呢?

头尾缺失快,但是也有弊端💦哈哈哈

如果空间还足够的时候,还是比较快的:时间复杂度为O(1)

当插入并且扩容时,就还是会变慢:O(n)

总之Arraylist适合查询,而不是修改操作

------------------------------------------------Linked list------------------------------------------------------------------------------------

看到Linked list就知道和链表肯定有关系!!

这个实际上就是双向链表

看到链表就知道修改比较方便了!!

链表修改只需要修改某两个指针的指向,而其他元素是不需要移动的,整体的性能非常快!

但是查询的时候只依靠指针移动来查询,因此查询性能不怎么样

总之Linkedlist是修改快,但是查询不怎么样

------------------------------------------------总结------------------------------------------------------------------------------

1.Array list 适用于 查询场景

2.linked list适用于 修改场景

实际使用的时候根据场景需求选择即可

嗨嗨嗨嗨!!!!实际上根据字面英文意思理解性记忆即可,Array数组,Linked链表

然后再根据不同的意思来延伸即可:比如链表就是适合修改,Array有索引就是查询快


相关推荐
用户1563068103512 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师4 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师8 小时前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_08 小时前
mac(m5)平台编译openjdk
java
唐青枫1 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马1 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261351 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261351 天前
Java 打印 Word 文档:从基础打印到高级设置
java
用户3521802454752 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜2 天前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈