408数据结构总结复习笔记一:线性表

408数据结构总结复习笔记一:线性表

从现在开始慢慢更新我的考研复习笔记系列吧~

PS:主要是我自己个人复习过程中觉得重点的点,大家仅供参考哈~

上岸!!!大家一起加油!

顺序表和链表的比较

顺序表 链表
存取/读写方式 可顺序存取,也可以随机存取 只能从表头开始顺序存取元素,无法实现随机存取!
按值查找 若无序,则T(n)=O(n);若有序,则可以采用折半查找,T(n)=O(logn) T(n)=O(n)
按序号查找 序号约等于数字下标,T(n)=O(1) T(n)=O(n)
插入和删除操作 插入和删除都需要移动数据,T(n)=O(n) 无需移动数据,只要修改指针就可以,T(n)=O(1)
逻辑结构和物理结构 逻辑上相邻,物理上也相邻 逻辑上相邻,物理上不相邻
空间分配 分为静态顺序表和动态顺序表。静态顺序表建立时就申请一片连续的空间,数据写满的情况下要再写入数据会造成数据溢出且无法扩大空间,而存储数据过少时又会存在空间浪费问题;动态顺序表建立时先申请一片连续的空间,当数据写满的情况下要再写入数据需要向系统再申请一片扩大的连续的空间,并移动数据到新的空间,释放旧空间。 分为普通链表和静态链表 ,普通链表创建时不需要申请一整片连续的空间地址,各个结点之间通过指针串联起来;静态链表与数组有一点类似,创建时需要申请一片连续的空间,各结点之间是连续的,但结点中又分为数据域和指针域,数据域存放数据,指针域存放逻辑上下一个结点的位置下标。

顺序表和链表的应用选取

  • 顺序表

    适用于查找、随机存取以及在表尾进行数据插入和删除操作的应用场景中

  • 链表

    适用于经常进行数据插入和删除操作的应用场景中

未完,想到再补充好了。。。

相关推荐
yugi9878382 分钟前
基于Matlab的晴空指数计算实现
开发语言·算法·matlab
星火开发设计12 分钟前
Python数列表完全指南:从基础到实战
开发语言·python·学习·list·编程·知识·期末考试
ADI_OP19 分钟前
ADAU1452的开发教程3:常规音频算法的开发(2)
算法·dsp开发·adi dsp中文资料·adi dsp·adi音频dsp·adi dsp开发教程
666HZ66620 分钟前
数据结构1.0 数据结构在学什么
数据结构·算法
googleccsdn22 分钟前
ENSP Pro Lab笔记:配置BGP EVPN VXLAN双栈(1)
网络·笔记
余瑜鱼鱼鱼25 分钟前
Java数据结构:从入门到精通(五)
数据结构
君义_noip31 分钟前
信息学奥赛一本通 1951:【10NOIP普及组】导弹拦截 | 洛谷 P1158 [NOIP 2010 普及组] 导弹拦截
c++·算法·csp-j·信息学奥赛
环黄金线HHJX.31 分钟前
《QuantumTuan ⇆ QT:Qt》
人工智能·qt·算法·编辑器·量子计算
jz_ddk31 分钟前
[实战] 射频相位噪声单位转换:从dBc/Hz到rad
算法·rf·射频·相位噪声·相噪
zl_vslam33 分钟前
SLAM中的非线性优-3D图优化之地平面约束(十五)
人工智能·算法·计算机视觉·3d