当前位置: 首页 > news >正文

线性数据结构:链表 LinkList

一、前言

链表的历史

于1955-1956年,由兰德公司的Allen Newell、Cliff Shaw和Herbert A. Simon开发了链表,作为他们的信息处理语言的主要数据结构。链表的另一个早期出现是由 Hans Peter Luhn 在 1953 年 1 月编写的IBM内部备忘录建议在链式哈希表中使用链表。

到 1960 年代初,链表和使用这些结构作为主要数据表示的语言的实用性已经很好地建立起来。MIT 林肯实验室的 Bert Green于 1961 年 3 月在 IRE Transactions on Human Factors in Electronics 上发表了一篇题为“用于符号操作的计算机语言”的评论文章,总结了链表方法的优点。1964 年 4 月,Bobrow 和 Raphael 的一篇评论文章“列表处理计算机语言的比较”发表在 ACM 通讯中。

二、链表数据结构

在计算机科学中,链表是数据元素的线性集合,元素的线性顺序不是由它们在内存中的物理地址给出的。它是由一组节点组成的数据结构,每个元素指向下一个元素,这些节点一起,表示线性序列。

在最简单的链表结构下,每个节点由数据和指针(存放指向下一个节点的指针)两部分组成,这种数据结构允许在迭代时有效地从序列中的任何位置插入或删除元素。

链表的数据结构通过链的连接方式,提供了可以不需要扩容空间就更高效的插入和删除元素的操作,在适合的场景下它是一种非常方便的数据结构。但在一些需要遍历、指定位置操作、或者访问任意元素下,是需要循环遍历的,这将导致时间复杂度的提升。

三、链表分类类型

链表的主要表现形式分为;单向链表双向链表循环链表,接下来我们分别介绍下。

1. 单向链表

单链表包含具有数据字段的节点以及指向节点行中的下一个节点的“下一个”字段。可以对单链表执行的操作包括插入、删除和遍历。

2. 双向链表

在“双向链表”中,除了下一个节点链接之外,每个节点还包含指向序列中“前一个”节点的第二个链接字段。这两个链接可以称为'forward('s')和'backwards',或'next'和'prev'('previous')。

3. 循环链表

在列表的最后一个节点中,链接字段通常包含一个空引用,一个特殊的值用于指示缺少进一步的节点。一个不太常见的约定是让它指向列表的第一个节点。在这种情况下,列表被称为“循环”或“循环链接”;否则,它被称为“开放”或“线性”。它是一个列表,其中最后一个指针指向第一个节点。

常见面试问题

  • 描述一下链表的数据结构?
  • Java 中 LinkedList 使用的是单向链表、双向链表还是循环链表?
  • 链表中数据的插入、删除、获取元素,时间复杂度是多少?
  • 什么场景下使用链表更合适?
http://www.lryc.cn/news/19810.html

相关文章:

  • 对restful的支持 rust-grpc-proxy
  • 【模拟集成电路】环路滤波器(LPF)设计
  • adb及cmd部分常用命令
  • ProtoBuf介绍
  • 数据结构:完全二叉树开胃菜小练习
  • mybatis与jpa
  • js 求解《初级算法》66. 加一
  • 力扣-游戏玩法分析
  • ZZNUOJ_用C语言编写程序实现1186 : 奖学金(结构体专题)(附完整源码)
  • 加油站ai系统视频监测 yolov5
  • 【JDK8新特性之Stream流-Stream结果收集案例实操】
  • Fiddler 抓包工具
  • 2023最新版网络安全保姆级指南,手把手带你从零基础进阶渗透攻防工程师
  • 排序基础之选择排序法
  • 2.24测试用例
  • 面试必刷101 Java题解 -- part 1
  • Python---关联与继承
  • 数据库行业的 “叛逆者”:大数据已“死”,MotherDuck 当立
  • Linux->进程优先级
  • loki 日志管理的安装部署使用
  • CTFer成长之路之反序列化漏洞
  • Python学习-----模块5.0(文件管理大师-->os模块)
  • 第45届世界技能大赛“网络安全”赛项浙江省选拔赛竞赛任务书
  • 【uniapp微信小程序】跨平台使用echarts的方案选择踩坑
  • WAF渗透攻防实践(16)
  • 高并发场景下机器性能优化sop
  • 【女程序员进大厂面试经验】
  • 计算机网络笔记(复试准备)第一章
  • WooCommerce 上传文件 Vanquish v71.6
  • zabbix4.0 Web页面配置 - 聚合图形的实现