【JAVA】顺序表和链表的区别--->【面试的那些事】

 1.顺序表:

优点:尾插、尾删效率较高,时间复杂度是O(1);支持随机访问,按下标检索元素;

缺点:在中间插入或删除元素时都涉及到元素的移动,效率较低,时间复杂度为O(N);且其长度固定,有时需要扩容。

2.链表:

优点:1.头插、头删效率高,时间复杂度是O(1);且没有空间限制,不需进行扩容

           2.若知道当前处理节点的前一个位置,则进行插入和删除的复杂度为O(1);

           3.若不知道当前处理节点的前一个位置,则进行插入和删除的复杂度为O(N);

缺点:不支持随机访问,查找元素效率低,需要遍历节点,时间复杂度是O(1)。

3.何时使用

1.需要频繁进行插入、删除操作时,可用链表存储

2.主要进行查找元素且对于插入删除需求较小时,则使用顺序表

1. 如何回答二者的区别???

(从共性出发回答问题):对数据的组织方式描述方式不一样

1.1 组织方式:

顺序表:底层是一个数组,逻辑和物理上都连续;
链表:由若干个节点构成的数据结构,逻辑上连续,物理上(内存)不连续(不一定)


1.2 操作方式:

1)顺序表:适合查找等操作,因为可以使用下标直接获取该位置处的元素
1)顺序表:需考虑空间利用率,考虑是否需要扩容
2.)链表:适合于频繁的插入和删除操作 ,不需和顺序表一样移动元素,链表的插入只需修改指向即可

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值