当前位置:首页 > 文章列表 > 文章 > python教程 > Python链表实现:单双链表详解

Python链表实现:单双链表详解

2026-04-11 18:52:32 0浏览 收藏
本文深入剖析了Python中单向与双向链表的手动实现要点,从Node和LinkedList类的基本设计、空链表边界处理、prev/next指针同步更新的常见陷阱,到__iter__和__len__的高效实现策略,既揭示了教学场景下理解指针逻辑的核心价值,也直言不讳地指出:在真实项目中,list和deque才是更安全、高效、内存友好的首选——手写链表仅适用于特定学习目的或极少数需原地节点操作的特殊场景,盲目自造反而易陷性能与维护泥潭。

Python链表怎么写_单向链表与双向链表的面向对象Python实现

Python里写单向链表,NodeLinkedList两个类就够了

单向链表的核心是每个节点只存一个指向后继的引用,不需要考虑回溯。实际写的时候,Node类只管数据和next指针,LinkedList类封装增删查逻辑——别把所有功能塞进一个类里,否则插入头尾、遍历、删除时容易混淆边界。

常见错误是初始化headNone后,在append()insert()里忘记判空,直接调head.next导致AttributeError: 'NoneType' object has no attribute 'next'

实操建议:

  • Node类的__init__只接收datanext默认设为None
  • LinkedListhead始终是NodeNone,不存“虚拟头节点”(除非你明确需要简化边界处理)
  • 插入到头部用new_node.next = self.head; self.head = new_node,比遍历到尾再插快得多
  • 遍历时用current = self.head然后while current:,别写while current.next:,否则漏掉最后一个节点

双向链表必须多管一个prev,但remove()insert_before()才真正值回票价

双向链表的Node要多一个prev属性,LinkedList操作时前后指针必须同步更新。这不是为了炫技,而是让某些操作从 O(n) 降到 O(1):比如已知某节点引用时删除它,或者在它前面插入新节点。

最容易踩的坑是更新prevnext顺序错乱。例如删除中间节点target时,如果先执行target.prev.next = target.next,再执行target.next.prev = target.prev,看起来没问题;但如果target是尾节点,target.nextNone,就会报AttributeError: 'NoneType' object has no attribute 'prev'

实操建议:

  • 所有涉及prevnext的赋值,先检查相邻节点是否为None,尤其处理头/尾时
  • remove(node)前,先确保node确实在链表中(可加if node not in self,但更高效的是维护_size或用身份比较)
  • insert_before(existing_node, new_node)insert_at_index()更符合双向链表的设计本意——它不依赖索引遍历
  • 不要为了省两行代码,在Node.__init__里把prevnext都默认设为self(即自环),这会让后续逻辑彻底混乱

__iter____len__要不要实现?看你怎么用

不实现__iter__,你就得手动写current = ll.head; while current: ...;实现了,就能直接for node in my_list:。同理,__len__返回缓存的_size还是每次遍历统计,直接影响性能。

问题在于:很多人实现__len__时每次遍历计数,结果在循环里反复调用len(my_list),把 O(1) 操作拖成 O(n²)。而如果维护_size,就得在每个修改结构的方法(appendremovepop)里同步更新——漏一次,len()就永远不准了。

实操建议:

  • 只要链表会被多次迭代,就实现__iter__,返回生成器(yield current.data)比构建列表更省内存
  • 如果链表长度常被查询(比如做条件判断if len(ll) > 10:),务必维护self._size并在所有变更方法中增减它
  • 不要在__iter__里返回self本身(即不实现__next__),否则多次迭代会相互干扰
  • __repr__可以返回f"LinkedList({list(self)})",方便调试,但注意大链表会卡住

真实项目里,99%的情况该用listcollections.deque,不是自己写链表

Python 的 list 是动态数组,按索引访问 O(1),尾部增删接近 O(1);collections.deque 是双向队列,头尾增删都是 O(1),内部用双向链表+块内存实现,但对外不暴露节点指针。

自己写链表的唯一合理场景,是教学理解指针逻辑、或极特殊需求(比如需要在任意节点原地拆分/拼接,且不能拷贝数据)。一旦涉及序列化、线程安全、内存视图、或与 NumPy/Pandas 交互,手写链表立刻变成维护黑洞。

容易被忽略的一点:Node实例本身有较大内存开销(每个对象带__dict__和引用计数),10 万个节点比等长list多占 2–3 倍内存。真要高性能,连__slots__都得加上,但那就离“教学清晰”越来越远了。

理论要掌握,实操不能落!以上关于《Python链表实现:单双链表详解》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

Mac上克隆Django项目教程详解Mac上克隆Django项目教程详解
上一篇
Mac上克隆Django项目教程详解
Java类初始化锁:静态资源加载一次详解
下一篇
Java类初始化锁:静态资源加载一次详解
查看更多
最新文章
资料下载
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    4276次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4630次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4508次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    6225次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    4889次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码