0

0

c++如何实现双向链表_c++链表数据结构编写【练习】

冰火之心

冰火之心

发布时间:2026-03-12 12:53:03

|

820人浏览过

|

来源于php中文网

原创

双向链表核心是node需显式初始化next/prev为nullptr,linkedlist仅维护head/tail;插入先连新节点指针再改原链邻居;删除须判空、同步更新head/tail、暂存待删指针;遍历时删节点要先保存next;拷贝/赋值需深拷贝并防自赋值。

c++如何实现双向链表_c++链表数据结构编写【练习】

怎么写一个能用的 NodeLinkedList

双向链表的核心是每个节点得存前后两个指针,不是单向链表加个 prev 就完事——漏掉初始化或赋值顺序不对,后面遍历直接崩。

实操建议:

人民网AIGC-X
人民网AIGC-X

国内科研机构联合推出的AI生成内容检测工具

下载
  • Node 构造函数里必须显式初始化 nextprevnullptr,否则野指针一访问就 Segmentation fault
  • LinkedList 类里只保留 headtail 两个指针,别存 size——除非你真需要 O(1) 获取长度,否则每次增删都要同步更新,容易错
  • 插入节点时,先连新节点的 next/prev,再改原链上邻居的指针;顺序反了会断链

示例(插入到尾部):

void push_back(int val) {
    Node* newNode = new Node(val);
    if (!head) {
        head = tail = newNode;
    } else {
        newNode->prev = tail;      // 先连新节点的 prev
        tail->next = newNode;      // 再改旧 tail 的 next
        tail = newNode;
    }
}

为什么 pop_front() 容易触发 double-free 或空指针解引用

删头节点不光是移动 head,还涉及内存释放时机和边界判断。很多练习代码在链表为空时仍调用 delete head,或者删完没把 tail 也置空。

立即学习C++免费学习笔记(深入)”;

常见错误现象:

  • 链表只剩一个节点时 pop_front() 后,headnullptr,但 tail 还指着已释放内存 → 后续 push_back()tail->next 崩溃
  • 没检查 head == nullptr 就直接 head->next,运行时报 bus error

实操建议:

  • 所有删除操作开头加 if (!head) return;
  • 删最后一个节点时,必须同时置空 headtail
  • delete 之前,把要删节点的指针先存到局部变量,删完立刻设为 nullptr(比如 Node* toDel = head; head = head->next; delete toDel; toDel = nullptr;

迭代器失效问题:为什么不能边遍历边 erase()

C++ 标准库容器的 erase() 返回下一个有效迭代器,但手写双向链表如果没实现类似机制,用 for (auto p = head; p; p = p->next) 遍历时调 erase(p)p->next 已经被改或释放,下一轮循环直接 UB。

使用场景:

  • 需要根据条件删多个节点(比如删所有偶数值)
  • 在遍历中动态修改结构,而不是只删固定位置

实操建议:

  • 不要依赖 p = p->next 继续循环;删节点前先保存 next
for (Node* p = head; p; ) {
    Node* next = p->next;
    if (p->val % 2 == 0) erase(p);
    p = next;
}
  • 如果封装了 erase(Node*),它内部应负责断开前后连接,但不负责内存释放——由调用方决定是否 delete,避免重复释放

拷贝构造和赋值运算符为什么常被忽略,又为什么必须写

默认生成的拷贝构造只是浅拷贝指针,两个 LinkedList 对象共享同一段堆内存,一个析构后另一个再访问就是悬垂指针,use-after-free 稳定复现。

性能 / 兼容性影响:

  • 不写深拷贝,传值参数、容器里存对象、临时对象返回都会出问题
  • 写了但没处理自赋值(a = a),可能把自己删空
  • std::unique_ptr<node></node> 可以规避手动管理,但练习目的就是练裸指针逻辑,所以必须手写

实操建议:

  • 拷贝构造:从 head 开始逐个 new 节点,用临时指针维护新链的 tail
  • 赋值运算符:先检查自赋值,再清空当前链(调用私有 clear()),再按拷贝构造逻辑重建
  • 析构函数里循环 delete 每个节点,别只删 head

复杂点在于所有指针操作都得对称:nextprev 必须成对设置/断开,少一个就导致某段内存永远无法释放,或者遍历卡死在环里。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

241

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

150

2025.10.17

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

492

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

382

2023.10.25

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

334

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

106

2025.10.23

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.1万人学习

C 教程
C 教程

共75课时 | 5.3万人学习

C++教程
C++教程

共115课时 | 21.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号