数据结构之链表

链表是一种常见的线性数据结构,它由一系列节点组成,每个节点包含了数据和指向下一个节点的引用。

链表中的元素在内层中不是连续存储的,这使得链表在插入和删除元素时更高效,因为不需要移动其他元素

链表的原理:

  • 节点结构:每个节点包含两个部分,数据域和指针域(数据和指向下一个节点的引用)
  • 头节点:链表的第一个节点
  • 尾节点:链表的最后一个节点,指向下一个节点的引用为None
  • 插入操作:可以在链表的任意位置插入新节点,只需要改变相邻节点的引用
  • 删除操作:可以删除链表的任意位置上的节点,只需要改变要删除的节点的相邻节点的引用
  • 从头节点开始,逐个节点查找,直到找到目标节点或达到链表结尾
python 复制代码
class LinkNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

class LinkedList:
    def __init__(self):
        self.head = None
        
    def append(self, val):
        """在链表末尾增加节点"""
        new_node = LinkNode(val)#注意:new_node.next = None
        if not self.head:
            self.head = new_node
            return
        current = self.head
        while current.next:
            current = current.next
        current.next = new_node

    def prepend(self, val):
        """在链表头部添加节点"""
        new_node = LinkNode(val)
        new_node.next = self.head
        self.head = new_node

    def delete(self, val):
        """删除第一个值为val的节点"""
        if not self.head:
            return
        if self.head.val == val:
            self.head = self.head.next

        current = self.head
        while current.next and current.next.val != val:
            current = current.next
        if current.next:
            current.next = current.next.next

    # def insert_after_node(self, prev_node, val):
    #     """在指定节点后插入新节点"""
    #     if not prev_node:
            

    def find(self, val):
        """查找值为val的节点,返回第一个值为val的节点/None"""
        current = self.head
        while current and current.val != val:
            current = current.next
        if current.next:
            return current.next
        return None
    
    def display(self):
        """打印链表内容"""
        elements = []
        current = self.head
        while current:
            elements.append(current.val)
            current = current.next
        print("->".join(map(str, elements)), end='')
        print('->None')

    # def size(self):
    #     """返回链表的长度,即链表元素的个数"""
相关推荐
WBluuue1 分钟前
数据结构与算法:二项式定理和二项式反演
c++·算法
nianniannnn2 分钟前
力扣104.二叉树的最大深度 110. 平衡二叉树
算法·leetcode·深度优先
_深海凉_12 分钟前
LeetCode热题100-只出现一次的数字
算法·leetcode·职场和发展
l1t18 分钟前
用wsl自带的python 3.10下载适用于3.12的pandas版本结合uv安装python 3.12模拟离线安装场景
python·pandas·uv
nianniannnn30 分钟前
力扣206.反转链表 92.反转链表II
算法·leetcode·链表
澈20737 分钟前
哈希表实战:从原理到手写实现
算法·哈希算法
飞Link39 分钟前
【AI大模型实战】万字长文肝透大语言模型(LLM):从底层原理解析到企业级Python项目落地
开发语言·人工智能·python·语言模型·自然语言处理
翻斗包菜43 分钟前
第 03 章 Python 操作 MySQL 数据库实战全解
数据库·python·mysql
旖-旎1 小时前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表
Run_Teenage1 小时前
Linux:认识信号,理解信号的产生和处理
linux·运维·算法