【数据结构】单链表的定义和操作

这篇具有很好参考价值的文章主要介绍了【数据结构】单链表的定义和操作。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【数据结构】单链表的定义和操作,数据结构与算法,数据结构,笔记,c++,c语言,学习,青少年编程,改行学it

目录

1.单链表的定义

2.单链表的创建和初始化

3.单链表的插入节点操作

4.单链表的删除节点操作

5.单链表的查找节点操作

6.单链表的更新节点操作

7.完整代码


🌈嗨!我是Filotimo__🌈。很高兴与大家相识,希望我的博客能对你有所帮助。

💡本文由Filotimo__✍️原创,首发于CSDN📚。

📣如需转载,请事先与我联系以获得授权⚠️。

🎁欢迎大家给我点赞👍、收藏⭐️,并在留言区📝与我互动,这些都是我前进的动力!

🌟我的格言:森林草木都有自己认为对的角度🌟。

【数据结构】单链表的定义和操作,数据结构与算法,数据结构,笔记,c++,c语言,学习,青少年编程,改行学it

【数据结构】单链表的定义和操作,数据结构与算法,数据结构,笔记,c++,c语言,学习,青少年编程,改行学it

1.单链表的定义

单链表由一系列节点组成,每个节点包含数据和一个指向下一个节点的指针(通常称为"next"指针)。单链表的最后一个节点指向空值(null)表示链表的结束。

单链表通常包含以下几个要素:

节点(Node):表示链表中的每个元素,通常包含数据和一个指向下一个节点的指针。
头结点(Head Node):代表链表的开始,通常不存储数据,它的next指针指向第一个实际节点。
尾节点(Tail Node):代表链表的最后一个节点,它的next指针指向空值(null)。
链表的长度:即链表中节点的数量。

头节点是第一个节点,尾节点是最后一个节点,它们都不存储数据元素。

单链表的特点是可以实现动态的插入和删除操作,但是访问某个节点时需要从头结点开始依次遍历链表,效率较低。

2.单链表的创建和初始化

创建单链表需要定义一个节点结构,该结构包含一个数据域和一个指向下一个节点的指针。首先创建一个头节点,将其指针设置为NULL,表示链表为空。

struct ListNode {
    int data;
    ListNode* next;
};

ListNode* createLinkedList() {
    ListNode* head = new ListNode();
    head->next = NULL;
    return head;
}

先定义名为 ListNode 的结构体。该结构体包含两个成员变量:int data 和 ListNode* next。

int data 用来存储节点的数据值,表示链表中的一个元素。

ListNode* next 是指向下一个节点的指针,表示链表中当前节点的下一个节点。

在函数 createLinkedList中,首先通过 new ListNode() 创建了一个新的节点对象,并将其地址赋值给 head 指针变量。然后,将 head->next 设置为 NULL,表示链表当前只有一个节点,并且没有下一个节点。最后,将 head 返回作为链表的头节点指针。

3.单链表的插入节点操作

在单链表中插入一个新节点需要先找到插入位置的前一个节点,然后将新节点插入到其后面。

void insertNode(ListNode* list, int value) {
    ListNode* newNode = new ListNode();
    newNode->data = value;
    newNode->next = NULL;

    ListNode* p = list;
    while (p->next != NULL) {
        p = p->next;
    }

    p->next = newNode;
}

ListNode* list表示链表的头节点指针

int value表示要插入节点的数值

函数中,先通过 `new ListNode()` 创建了一个新的节点对象,并将其地址赋给 `newNode` 指针变量。然后,将 `value` 的值赋给 `newNode->data`,即将要插入节点的数值存储到节点的 `data` 成员变量中。接着,将 `newNode->next` 设置为 `NULL`,表示新节点的下一个节点暂时为空。

再通过创建一个指针变量 `p`,将其初始化为 `list`,即将其指向链表的头节点。使用循环遍历链表,直到找到最后一个节点(即 `p->next = NULL`)。在每次循环迭代中,通过 `p = p->next` 将指针 `p` 移动到下一个节点。

在循环结束后,将新节点 `newNode` 插入到链表的最后一个节点的后面,即将最后一个节点的 `next` 指针指向 `newNode`。

4.单链表的删除节点操作

删除单链表中的一个节点也需要找到待删除节点的前一个节点,将其指针指向待删除节点的下一个节点,然后释放待删除节点的内存。

void deleteNode(ListNode* list, int value) {
    ListNode* p = list;
    while (p->next != NULL) {
        if (p->next->data == value) {
            ListNode* temp = p->next;
            p->next = temp->next;
            delete temp;
            break;
        }
        p = p->next;
    }
}

函数中,首先创建一个指针变量p,将其初始化为list,即将其指向链表的头节点。然后,使用循环遍历链表,直到找到节点数值等于value的节点,或者遍历到链表的最后一个节点。

在每次循环迭代中,通过判断p->next->data是否等于value,确定是否找到了需要删除的节点。如果找到了目标节点,则创建一个临时指针变量 `temp`,将其指向待删除节点的地址。通过 `p->next = temp->next` 更新前一个节点的 `next` 指针,跳过待删除节点。使用 `delete temp` 释放内存,删除待删除节点,并通过 `break` 语句跳出循环。

5.单链表的查找节点操作

查找单链表中某个特定值的节点,需要遍历链表,逐个比较节点的数据域。

ListNode* findNode(ListNode* list, int value) {
    ListNode* p = list;
    while (p->next != NULL) {
        if (p->next->data == value) {
            return p->next;
        }
        p = p->next;
    }
    return NULL;  // 未找到返回NULL
}

这个函数,使用循环遍历链表,直到找到节点数值等于value的节点,或者遍历到链表的最后一个节点。在每次循环迭代中,通过判断p->next->data是否等于value,确定是否找到了需要查找的节点。如果找到了目标节点,则直接返回该节点的指针p->next。

6.单链表的更新节点操作

更新单链表中某个节点的值,需要先找到该节点,然后修改其数据域的值。

void updateNode(ListNode* list, int oldValue, int newValue) {
    ListNode* p = findNode(list, oldValue);
    if (p != NULL) {
        p->data = newValue;
    }
}

函数的参数:

ListNode* list表示链表的头节点指针

oldValue表示待更新节点的旧数值

newValue表示待更新节点的新数值

在函数中,首先通过调用indNode函数来查找链表中数值为oldValue的节点,将返回的节点指针赋值给p。

接着,通过判断p是否为NULL,即是否找到了待更新的节点。如果p != NULL,则说明找到了需要更新的节点,将该节点的data成员变量的值更新为newValue,即p->data = newValue。

7.完整代码

#include <iostream>

struct ListNode {
    int data;
    ListNode* next;
};

ListNode* createLinkedList() {
    ListNode* head = new ListNode();
    head->next = NULL;
    return head;
}

void insertNode(ListNode* list, int value) {
    ListNode* newNode = new ListNode();
    newNode->data = value;
    newNode->next = NULL;

    ListNode* p = list;
    while (p->next != NULL) {
        p = p->next;
    }

    p->next = newNode;
}

void deleteNode(ListNode* list, int value) {
    ListNode* p = list;
    while (p->next != NULL) {
        if (p->next->data == value) {
            ListNode* temp = p->next;
            p->next = temp->next;
            delete temp;
            break;
        }
        p = p->next;
    }
}

ListNode* findNode(ListNode* list, int value) {
    ListNode* p = list;
    while (p->next != NULL) {
        if (p->next->data == value) {
            return p->next;
        }
        p = p->next;
    }
    return NULL;
}

void updateNode(ListNode* list, int oldValue, int newValue) {
    ListNode* p = findNode(list, oldValue);
    if (p != NULL) {
        p->data = newValue;
    }
}

void printLinkedList(ListNode* list) {
    ListNode* p = list->next;
    while (p != NULL) {
        std::cout << p->data << " ";
        p = p->next;
    }
    std::cout << std::endl;
}

int main() {
    ListNode* list = createLinkedList();

    // 插入节点
    insertNode(list, 1);
    insertNode(list, 2);
    insertNode(list, 3);
    insertNode(list, 4);
    std::cout << "链表:";
    printLinkedList(list);

    // 删除节点
    deleteNode(list, 2);
    std::cout << "删除节点2后的链表:";
    printLinkedList(list);

    // 查找节点
    ListNode* node = findNode(list, 3);
    if (node != NULL) {
        std::cout << "找到节点3" << std::endl;
    } else {
        std::cout << "未找到节点3" << std::endl;
    }

    // 更新节点
    updateNode(list, 3, 5);
    std::cout << "更新节点3的值为5后的链表:";
    printLinkedList(list);

    return 0;
}

输出结果如下:

【数据结构】单链表的定义和操作,数据结构与算法,数据结构,笔记,c++,c语言,学习,青少年编程,改行学it文章来源地址https://www.toymoban.com/news/detail-785184.html

到了这里,关于【数据结构】单链表的定义和操作的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【数据结构与算法】单链表的排序算法(选择,冒泡,递归)

    目录 选择排序 冒泡排序 快速排序 合并两条链表并排序 选择排序 链表的选择排序思想与数组的排序类似,但是链表需要先找到里面最小或者最大的值,然后将这个值用改链语句进行操作 我们先看这个改链语句的操作(min是笔者打错了应该是max,但是图已经画好了就没有改)

    2024年02月04日
    浏览(56)
  • 【数据结构与算法】单链表的插入和删除

    🔥 本文由 程序喵正在路上 原创,CSDN首发! 💖 系列专栏: 数据结构与算法 🌠 首发时间:2022年9月21日 🦋 欢迎关注🖱点赞👍收藏🌟留言🐾 🌟 一以贯之的努力 不得懈怠的人生 众所周知,顺序表中的每个结点中只存放数据元素,其优缺点为: 优点:可随机存取,存储

    2024年02月07日
    浏览(43)
  • 【数据结构】单链表的基本操作 (C语言版)

    目录 一、单链表 1、单链表的定义: 2、单链表的优缺点: 二、单链表的基本操作算法(C语言) 1、宏定义 2、创建结构体 3、初始化 4、插入 4、求长度 5、清空 6、销毁  7、取值 8、查找 9、删除 10、头插法创建单链表 11、尾插法创建单链表 三、单链表的全部代码(C语言)

    2024年01月22日
    浏览(60)
  • 【数据结构】C语言实现单链表的基本操作

    大家好,很高兴又和大家见面啦!!! 在上一篇中,我们详细介绍了单链表的两种创建方式——头插法与尾插法,相信大家现在对这两种方式都已经掌握了。今天咱们将继续介绍单链表的基本操作——查找、插入与删除。在开始今天的内容之前,我们先通过尾插法创建一个单

    2024年02月03日
    浏览(65)
  • 【玩转408数据结构】线性表——单链表的定义以及增删改查(线性表的链式表示 上)

            到这里我们已经了解到线性表是具有 相同数据类型 的 有限个数据元素 序列,而线性表的顺序存储也就是顺序表,顺序表的存储形式十分直观,我们在实现时使用数组进行实现,但顺序表在插入或者删除元素时需要移动大量元素,那么怎么样才能在插入删除元素时不

    2024年02月21日
    浏览(57)
  • 【数据结构】 循环单链表的基本操作 (C语言版)

    目录 一、循环单链表 1、循环单链表的定义: 2、循环单链表的优缺点: 二、循环单链表的基本操作算法(C语言)    1、宏定义  2、创建结构体 3、循环单链表的初始化  4、循环单链表的插入 5、求单链表长度 6、循环单链表的清空 7、循环单链表的销毁 8、循环单链表的取

    2024年01月22日
    浏览(60)
  • 【数据结构与算法】单链表的增删查改(附源码)

      这么可爱的猫猫不值得点个赞吗 😽😻 目录 一.链表的概念和结构 二.单链表的逻辑结构和物理结构 1.逻辑结构  2.物理结构 三.结构体的定义 四.增加 1.尾插   SListpushback 2.头插  SListpushfront 五.删除 1.尾删  SListpopback 2.头删  SListpopfront 六.查找  插入  释放   打印 1.查找

    2024年02月02日
    浏览(75)
  • 单链表的建立(头插法、尾插法)(数据结构与算法)

    如果要把很多个数据元素存到一个单链表中,如何操作? 1.初始化一个单链表 2. 每次取一个数据元素,插入到表尾/表头 尾插法建立的单链表元素顺序与输入数据集合的顺序相同,即按照输入数据的顺序排列。 使用尾插法建立单链表的一个常见应用是在计算机科学中进行数据

    2024年04月11日
    浏览(44)
  • 【数据结构与算法】深入浅出:单链表的实现和应用

      🌱博客主页:青竹雾色间. 😘博客制作不易欢迎各位👍点赞+⭐收藏+➕关注  ✨ 人生如寄,多忧何为  ✨ 目录 前言 单链表的基本概念 节点 头节点 尾节点 单链表的基本操作 创建单链表 头插法: 尾插法: 插入(增)操作  删除(删)操作: 查找(查)操作: 修改(改

    2024年02月08日
    浏览(75)
  • C语言简单的数据结构:单链表的有关算法题(2)

    接着我们介绍后面的三道题,虽然代码变多了但我们的思路更加通顺了 题目链接:https://leetcode.cn/problems/merge-two-sorted-lists/ 创建新链表,遍历原链表,将节点值小的进行尾插到新链表中 这里要多次进行对NULL的判断,开始传入列表,中间newHead的判断,循环出来一个为NULL的判断

    2024年04月15日
    浏览(64)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包