算法竞赛阶段二-数据结构(38)数据结构动态链表list

动态链表(List)的基本概念

动态链表是一种线性数据结构,通过节点间的指针连接实现动态内存分配。与数组不同,链表的大小可随需增减,插入和删除操作的时间复杂度为 O(1)(已知位置时),但随机访问需要 O(n) 时间。

常见动态链表类型

  1. 单向链表

    每个节点包含数据和指向下一个节点的指针。

    python 复制代码
    class Node:
        def __init__(self, data):
            self.data = data
            self.next = None
  2. 双向链表

    节点包含指向前驱和后继的指针,支持双向遍历。

    python 复制代码
    class Node:
        def __init__(self, data):
            self.data = data
            self.prev = None
            self.next = None
  3. 循环链表

    尾节点指向头节点,形成闭环。

动态链表的操作

插入节点

在头部插入:

python 复制代码
new_node = Node(data)
new_node.next = head
head = new_node

在中间插入(已知前驱节点 prev_node):

python 复制代码
new_node.next = prev_node.next
prev_node.next = new_node

删除节点

删除头节点:

python 复制代码
head = head.next

删除中间节点(已知前驱节点 prev_node):

python 复制代码
prev_node.next = prev_node.next.next

动态链表的优缺点

优点

  • 内存按需分配,避免静态数组的浪费。
  • 插入/删除高效,无需移动其他元素。

缺点

  • 随机访问效率低。
  • 需要额外空间存储指针。

动态链表的应用场景

  • 实现栈、队列等抽象数据类型。
  • 内存管理中的动态分配(如操作系统的空闲内存块管理)。
  • 需要频繁插入/删除的场景(如实时系统)。

示例:单向链表的完整实现

python 复制代码
class LinkedList:
    def __init__(self):
        self.head = None

    def append(self, data):
        new_node = Node(data)
        if not self.head:
            self.head = new_node
            return
        last = self.head
        while last.next:
            last = last.next
        last.next = new_node

    def print_list(self):
        current = self.head
        while current:
            print(current.data, end=" -> ")
            current = current.next
        print("None")

注意事项

  • 动态链表需手动管理内存(如 C/C++ 中需释放节点)。
  • 在 Python/Java 等语言中,垃圾回收机制自动处理内存释放。
相关推荐
快去睡觉~33 分钟前
力扣1005:k次取反后最大化的数组和
数据结构·算法·leetcode
想不明白的过度思考者42 分钟前
初识数据结构——Map和Set:哈希表与二叉搜索树的魔法对决
数据结构·散列表
smilejingwei1 小时前
数据分析编程第二步: 最简单的数据分析尝试
数据库·算法·数据分析·esprocspl
天意生信云1 小时前
生信分析自学攻略 | R语言数据筛选和修改
数据结构·经验分享·r语言
月盈缺1 小时前
学习嵌入式第二十三天——数据结构——栈
数据结构·学习
草莓熊Lotso1 小时前
【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day10
c语言·开发语言·经验分享·算法·强化
张同学的IT技术日记2 小时前
详细实例说明+典型案例实现 对迭代法进行全面分析 | C++
算法
Coovally AI模型快速验证2 小时前
全景式综述|多模态目标跟踪全面解析:方法、数据、挑战与未来
人工智能·深度学习·算法·机器学习·计算机视觉·目标跟踪·无人机
草莓熊Lotso3 小时前
【C++】--函数参数传递:传值与传引用的深度解析
c语言·开发语言·c++·其他·算法
不知名。。。。。。。。3 小时前
算法 ----- 链式
算法