线性表学习小结

线性表

  • 线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串…
  • 线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。
    顺序表
  • 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。
    链表
  • 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。
  • 链表的结构非常多样,以下情况组合起来就有8种链表结构:
    单向、双向
    带头、不带头
    循环、非循环
  • 常用链表:
    1.无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。另外这种结构在笔试面试中出现很多。
    2.带头循环单链表:结构较无头单向非循环链表简单。实际操作当中使用较少。
    不带头双向循环链表:在Java的集合框架库中LinkedList底层实现就是不带头双向循环链表。
  • 顺序表与链表的比较:
    在这里插入图片描述
    经典面试题
    1. 删除链表中等于给定值 val 的所有节点
    2.反转一个单链表
    3.查找链表中倒数第k个结点
    4.合并两个有序链表
    5.删除链表中重复结点
    6.复制复杂链表


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部