【数据结构与算法】第3课—数据结构之单链表

文章目录

  • [1. 什么是链表](#1. 什么是链表)
  • [2. 单链表](#2. 单链表)
    • [2.1 单链表的初始化和打印](#2.1 单链表的初始化和打印)
    • [2.2 单链表的尾插和头插](#2.2 单链表的尾插和头插)
    • [2.3 单链表的尾删和头删](#2.3 单链表的尾删和头删)
    • [2.4 单链表查找节点](#2.4 单链表查找节点)
    • [2.5 单链表在指定位置之前/之后插入数据](#2.5 单链表在指定位置之前/之后插入数据)
    • [2.6 单链表删除节点和删除pos之后的节点](#2.6 单链表删除节点和删除pos之后的节点)
    • [2.7 销毁链表](#2.7 销毁链表)
  • [3. 单链表和顺序表对比](#3. 单链表和顺序表对比)

1. 什么是链表

  • 链表是在逻辑结构上连续,而在物理结构上不一定连续的存储结构
  • 链表由一个一个的节点组成,并且这些节点是在堆上申请空间
  • 单链表的每个节点一般有两个变量,一个变量存储数据,另一个变量里面是下一个节点的地址,最后一个节点里面的那个变量存储的是空指针


2. 单链表

  • 从前往后,单向的一个链表

2.1 单链表的初始化和打印

  • 初始化

  • 打印单链表

2.2 单链表的尾插和头插

  • 尾插



  • 头插



2.3 单链表的尾删和头删

  • 尾删




  • 头删



2.4 单链表查找节点



2.5 单链表在指定位置之前/之后插入数据

  • 单链表在指定位置之前插入数据


  • 单链表在指定位置之后插入数据



2.6 单链表删除节点和删除pos之后的节点

  • 单链表删除节点pos


  • 单链表删除节点pos之后的节点


2.7 销毁链表




3. 单链表和顺序表对比

  • 顺序表头部/中间的插入删除的时间复杂度是O(N),而单链表头部的插入删除、删除指定位置之后的节点、指定位置之后插入数据的时间复杂度是O(1)
  • 而顺序表尾部插入/删除的时间复杂度是O(1),单链表尾部插入/删除、删除指定位置节点、指定位置之前插入节点的时间复杂度是O(N)
  • 顺序表需要增容,而且存在一定的空间浪费,而单链表每次只需要申请一个节点大小,不存在浪费空间的情况
相关推荐
道不尽世间的沧桑36 分钟前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
阿里云云原生42 分钟前
山石网科×阿里云通义灵码,开启研发“AI智造”新时代
网络·人工智能·阿里云·ai程序员·ai程序员体验官
bin91534 小时前
DeepSeek 助力 Vue 开发:打造丝滑的复制到剪贴板(Copy to Clipboard)
前端·javascript·vue.js·ecmascript·deepseek
晴空万里藏片云5 小时前
elment Table多级表头固定列后,合计行错位显示问题解决
前端·javascript·vue.js
奶球不是球5 小时前
el-button按钮的loading状态设置
前端·javascript
无责任此方_修行中7 小时前
每周见闻分享:杂谈AI取代程序员
javascript·资讯
小冷爱学习!7 小时前
华为动态路由-OSPF-完全末梢区域
服务器·网络·华为
夏末秋也凉7 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
王老师青少年编程8 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛
技术小齐8 小时前
网络运维学习笔记 016网工初级(HCIA-Datacom与CCNA-EI)PPP点对点协议和PPPoE以太网上的点对点协议(此处只讲华为)
运维·网络·学习