【数据结构】C++实现链表数据结构

C++实现链表数据结构

前言

在数据结构课程中,链表是一种非常基础且重要的数据结构。链表允许动态地进行内存分配,因此相比数组具有更高的灵活性。本文将介绍如何使用C++实现一个单链表,并展示其基本操作,如插入、删除和遍历。

单链表节点结构

首先,我们需要定义链表的节点结构。每个节点包含一个数据域和一个指向下一个节点的指针。

cpp 复制代码
struct Node {
    int data;
    Node* next;
    
    Node(int val) : data(val), next(nullptr) {}
};

单链表类

接下来,我们定义一个单链表类,包含头节点指针和基本的链表操作。

cpp 复制代码
class LinkedList {
private:
    Node* head;

public:
    LinkedList() : head(nullptr) {}

    ~LinkedList() {
        Node* current = head;
        Node* nextNode;
        while (current != nullptr) {
            nextNode = current->next;
            delete current;
            current = nextNode;
        }
    }

    // 在链表末尾插入新节点
    void append(int value) {
        Node* newNode = new Node(value);
        if (head == nullptr) {
            head = newNode;
        } else {
            Node* temp = head;
            while (temp->next != nullptr) {
                temp = temp->next;
            }
            temp->next = newNode;
        }
    }

    // 删除值为value的第一个节点
    bool remove(int value) {
        if (head == nullptr) return false;

        if (head->data == value) {
            Node* temp = head;
            head = head->next;
            delete temp;
            return true;
        }

        Node* temp = head;
        while (temp->next != nullptr && temp->next->data != value) {
            temp = temp->next;
        }

        if (temp->next == nullptr) return false;

        Node* nodeToDelete = temp->next;
        temp->next = temp->next->next;
        delete nodeToDelete;
        return true;
    }

    // 打印链表中的所有元素
    void printList() const {
        Node* temp = head;
        while (temp != nullptr) {
            std::cout << temp->data << " ";
            temp = temp->next;
        }
        std::cout << std::endl;
    }
};

使用示例

下面是一个简单的使用示例,展示如何创建链表、插入节点、删除节点和打印链表。

cpp 复制代码
int main() {
    LinkedList list;
    list.append(1);
    list.append(2);
    list.append(3);
    list.printList();  // 输出: 1 2 3

    list.remove(2);
    list.printList();  // 输出: 1 3

    return 0;
}

总结

本文介绍了如何使用C++实现一个单链表数据结构,并展示了其基本操作。链表是数据结构中的基础,理解链表的实现和操作对于学习更复杂的数据结构非常有帮助。希望这篇文章能帮助你更好地理解和掌握链表。

相关推荐
LuminousCPP6 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
一个不知名程序员www22 分钟前
算法学习入门---算法题DAY1
c++·算法
桀人34 分钟前
C++——内存管理——new和delete的超详细解析
开发语言·c++
Shadow(⊙o⊙)35 分钟前
Shell进程替换,自定义Shell解释器——字符串库函数灵活操作!
linux·运维·服务器·开发语言·c++·学习
_F_y44 分钟前
树形 DP 从入门到进阶:普通树形DP、树形背包、换根DP
c++·动态规划
Hua-Jay1 小时前
OpenCV联合C++/Qt 学习笔记(二十三)----图像校正及单目位姿估计
c++·笔记·qt·opencv·学习·计算机视觉
charlie1145141911 小时前
现代C++特性指南(4)——完美转发与移动语义实战
开发语言·c++·现代c++
开压路机1 小时前
数据结构:图
数据结构·算法
小白|1 小时前
cann-learning-hub:昇腾CANN社区学习中心完全指南
java·c++·算法
mirror_zAI1 小时前
C++ 仿 QQ 聊天室项目:Qt 客户端 + epoll 服务端 + Reactor 架构(含源码)
c++·qt·架构