博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线性表——顺序表与单链表学习小结
阅读量:5775 次
发布时间:2019-06-18

本文共 688 字,大约阅读时间需要 2 分钟。

线性表

  • 线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...
  • 线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物
    理上存储时,通常以数组和链式结构的形式存储。

    顺序表

  • 顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

    链表

  • 链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。
  • 链表的结构非常多样,以下情况组合起来就有8种链表结构:
    单向、双向
    带头、不带头
    循环、非循环
  • 常用链表:
    1. 无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。另外这种结构在笔试面试中出现很多。
    2. 带头循环单链表:结构较无头单向非循环链表简单。实际操作当中使用较少。
    3. 不带头双向循环链表:在Java的集合框架库中LinkedList底层实现就是不带头双向循环链表。

顺序表与链表的比较:

线性表——顺序表与单链表学习小结

经典面试题:

1.删除链表中等于给定值 val 的所有节点。

2.反转一个单链表。
3.查找链表中倒数第k个结点
4.合并两个有序链表
5.删除链表中重复结点
6.复制复杂链表

封装:

将线性表的一些基本功能(增删查改)写在一个类里。使用时只要创建一个对象,用 对象.方法 调用即可

转载于:https://blog.51cto.com/14233363/2410218

你可能感兴趣的文章
赵雅智:js知识点汇总
查看>>
二维有序数组查找数字
查看>>
20个Linux服务器性能调优技巧
查看>>
多重影分身:一套代码如何生成多个小程序?
查看>>
Oracle将NetBeans交给了Apache基金会
查看>>
填坑记:Uncaught RangeError: Maximum call stack size exceeded
查看>>
SpringCloud之消息总线(Spring Cloud Bus)(八)
查看>>
DLA实现跨地域、跨实例的多AnalyticDB读写访问
查看>>
实时编辑
查看>>
KVO原理分析及使用进阶
查看>>
【348天】每日项目总结系列086(2018.01.19)
查看>>
【294天】我爱刷题系列053(2017.11.26)
查看>>
Microsoft发布了Azure Bot Service和LUIS的GA版
查看>>
Google发布Puppeteer 1.0
查看>>
.NET开源现状
查看>>
可替换元素和非可替换元素
查看>>
2016/08/25 The Secret Assumption of Agile
查看>>
(Portal 开发读书笔记)Portlet间交互-PortletSession
查看>>
搭建vsftpd服务器,使用匿名账户登入
查看>>
AMD改善Linux驱动,支持动态电源管理
查看>>