0

0

C++如何实现一个链表_C++手写单向链表的实现方法

穿越時空

穿越時空

发布时间:2025-11-12 12:12:04

|

475人浏览过

|

来源于php中文网

原创

首先定义节点结构ListNode,包含值和指向下一节点的指针,并提供构造函数初始化;接着实现LinkedList类,包含head指针及append、remove、find、print等方法,分别用于尾部插入、按值删除、查找和遍历输出,同时在析构函数中释放内存;最后通过main函数测试链表的基本操作,验证插入、删除、查找功能正确性。

c++如何实现一个链表_c++手写单向链表的实现方法

在C++中实现一个单向链表,核心是定义节点结构和管理指针操作。通过手动管理内存和指针链接,可以深入理解数据结构的底层机制。下面是一个简洁、实用的手写单向链表实现方法。

定义链表节点结构

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

struct ListNode {
    int val;
    ListNode* next;
    ListNode(int x) : val(x), next(nullptr) {}
};

这里使用构造函数初始化节点值,并将指针设为nullptr,避免野指针问题。

实现链表类的基本操作

封装链表操作到一个类中,便于管理和调用。常见操作包括插入、删除、查找和遍历。

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

插入节点(尾部插入):

  • 如果链表为空,新节点成为头节点。
  • 否则遍历到末尾,将最后一个节点的next指向新节点。

删除节点(按值删除):

情感家园企业站5.0 多语言多风格版
情感家园企业站5.0 多语言多风格版

一套面向小企业用户的企业网站程序!功能简单,操作简单。实现了小企业网站的很多实用的功能,如文章新闻模块、图片展示、产品列表以及小型的下载功能,还同时增加了邮件订阅等相应模块。公告,友情链接等这些通用功能本程序也同样都集成了!同时本程序引入了模块功能,只要在系统默认模板上创建模块,可以在任何一个语言环境(或任意风格)的适当位置进行使用!

下载
  • 从头开始查找目标值。
  • 找到后调整前一个节点的next指针,跳过目标节点。
  • 释放被删除节点的内存,防止泄漏。

查找节点:

  • 从头节点开始逐个比较,直到找到匹配值或到达链表末尾。

完整示例代码

#include 
using namespace std;

struct ListNode { int val; ListNode* next; ListNode(int x) : val(x), next(nullptr) {} };

class LinkedList { public: ListNode* head;

LinkedList() : head(nullptr) {}

// 尾插法
void append(int val) {
    ListNode* newNode = new ListNode(val);
    if (!head) {
        head = newNode;
        return;
    }
    ListNode* cur = head;
    while (cur-youjiankuohaophpcnnext) {
        cur = cur-youjiankuohaophpcnnext;
    }
    cur-youjiankuohaophpcnnext = newNode;
}

// 删除第一个等于val的节点
bool remove(int val) {
    if (!head) return false;
    if (head-youjiankuohaophpcnval == val) {
        ListNode* tmp = head;
        head = head-youjiankuohaophpcnnext;
        delete tmp;
        return true;
    }
    ListNode* cur = head;
    while (cur-youjiankuohaophpcnnext && cur-youjiankuohaophpcnnext-youjiankuohaophpcnval != val) {
        cur = cur-youjiankuohaophpcnnext;
    }
    if (cur-youjiankuohaophpcnnext) {
        ListNode* tmp = cur-youjiankuohaophpcnnext;
        cur-youjiankuohaophpcnnext = tmp-youjiankuohaophpcnnext;
        delete tmp;
        return true;
    }
    return false;
}

// 查找是否存在某个值
bool find(int val) {
    ListNode* cur = head;
    while (cur) {
        if (cur-youjiankuohaophpcnval == val) return true;
        cur = cur-youjiankuohaophpcnnext;
    }
    return false;
}

// 打印链表
void print() {
    ListNode* cur = head;
    while (cur) {
        cout zuojiankuohaophpcnzuojiankuohaophpcn cur-youjiankuohaophpcnval zuojiankuohaophpcnzuojiankuohaophpcn " ";
        cur = cur-youjiankuohaophpcnnext;
    }
    cout zuojiankuohaophpcnzuojiankuohaophpcn endl;
}

// 析构函数释放内存
~LinkedList() {
    while (head) {
        ListNode* tmp = head;
        head = head-youjiankuohaophpcnnext;
        delete tmp;
    }
}

};

测试与使用

创建链表对象并进行基本操作验证功能正确性。

int main() {
    LinkedList list;
    list.append(1);
    list.append(2);
    list.append(3);
    list.print();        // 输出: 1 2 3
list.remove(2);
list.print();        // 输出: 1 3

cout zuojiankuohaophpcnzuojiankuohaophpcn list.find(3) zuojiankuohaophpcnzuojiankuohaophpcn endl;  // 输出: 1 (true)

return 0;

}

基本上就这些。这个实现涵盖了单向链表的核心操作,适合学习和基础应用。注意手动管理new和delete,避免内存问题。不复杂但容易忽略细节,比如空指针判断和析构处理。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.09.27

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

7

2025.12.22

空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

20

2025.11.16

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

339

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1062

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

167

2025.09.12

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

266

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

62

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.6万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 18.5万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.1万人学习

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

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