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

目录

1.单链表的定义

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

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

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

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

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

7.完整代码


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

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

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

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

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

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;
}

输出结果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/226556.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2023-12-16:用go语言,给定整数数组arr,求删除任一元素后, 新数组中长度为k的子数组累加和的最大值。 来自字节。

2023-12-16&#xff1a;用go语言&#xff0c;给定整数数组arr&#xff0c;求删除任一元素后&#xff0c; 新数组中长度为k的子数组累加和的最大值。 来自字节。 答案2023-12-16&#xff1a; 来自左程云。 灵捷3.5 大体步骤如下&#xff1a; 算法 maxSum1 分析&#xff1…

网络时间服务器

本章主要介绍网络时间服务器。 使用chrony配置时间服务器 配置chrony客户端向服务器同步时间 1 时间同步的必要性 一些服务对时间要求非常严格&#xff0c;例如&#xff0c;图所示的由三台服务器搭建的ceph集群。 这三台服务器的时间必须保持一致&#xff0c;如果不一致&#…

杰卡德的故事

三个男人分别是杰卡德距离 杰卡德相似系数和杰卡德系数 杰卡德相似系数和杰卡德距离是互为相反数的。 杰卡德系数和杰卡德距离是不是一回事 感觉是一回事

DevOps搭建(二)-阿里云镜像仓库的使用详解

博主介绍&#xff1a;Java领域优质创作者,博客之星城市赛道TOP20、专注于前端流行技术框架、Java后端技术领域、项目实战运维以及GIS地理信息领域。 &#x1f345;文末获取源码下载地址&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3fb;…

NVIDIA A100 PCIE 40GB k8s-device-plugin install in kubernetes

文章目录 1. 目标2. 简介2.1 英伟达 A100 技术规格2.2 架构优势2.3 显卡跑分对比2.4 英伟达 A100 与 kubernetes 3. 安装 NVIDIA A100 GPU 40G 硬件4. NVIDIA R450 datacenter driver5. NVIDIA Container Toolkit6. 创建 runtimeclass5. MIG Strategies6. 配置仓库7. 下载镜像8…

Spring cloud - 断路器 Resilience4J

其实文章的标题应该叫 Resilience4J&#xff0c;而不是Spring Cloud Resilience4J&#xff0c;不过由于正在对Spring cloud的一系列组件进行学习&#xff0c;为了统一&#xff0c;就这样吧。 概念区分 首先区分几个概念 Spring cloud 断路器&#xff1a;Spring Cloud的官网对…

【Django-03】模型常用的增删改查

Django Model 增删改查函数 QuerySet 对象all()filter()get()exclude()values()distinct()支持的表达式组合使用创建数据更新数据删除数据F()函数Q()函数 class Grade(models.Model):id models.AutoField(verbose_name自增id, name"id", primary_keyTrue)grade_name…

02_Web开发基础之JavaScript

Web开发基础之JavaScript 学习目标和内容 1、能够描述Javascript的作用 2、能够使用分支结构if语句逻辑判断 3、能够使用其中一种循环语句 4、能够定义javaScript中的函数 5、能够定义javaScript中的对象 6、能够描述DOM的作用 7、能够通过DOM操作HTML标签元素及其属性 8、能够…

1.2 【应用开发】开发一个基本的Screen应用

一&#xff0c;Screen应用开发简述 QNX Screen图形子系统是一个图形框架&#xff0c;因此&#xff0c;使用该框架开发的应用程序在复杂性和功能上可能会有很大差异。也就是说&#xff0c;大多数Screen应用程序在简化后&#xff0c;会执行某种渲染&#xff0c;以便在显示器上显…

走进暄桐教室 一起观看暄桐同学作品及感受

暄桐是一间传统美学教育教室&#xff0c;创办于2011年&#xff0c;林曦是创办人和授课老师&#xff0c;教授以书法为主的传统文化和技艺&#xff0c;旨在以书法为起点&#xff0c;亲近中国传统之美&#xff0c;以实践和所得&#xff0c;滋养当下生活。其实&#xff0c;暄桐教室…

vue表单输入绑定

基础用法 你可以用 v-model 指令在表单 <input>、<textarea> 及 <select> 元素上创建双向数据绑定。它会根据控件类型自动选取正确的方法来更新元素。尽管有些神奇&#xff0c;但 v-model 本质上不过是语法糖。它负责监听用户的输入事件以更新数据&#xff0…

大O记法了解

1、概念 大O记法&#xff08;Big O notation&#xff09;是一种用于描述算法时间复杂度的一种标记法。它表示了算法在最坏情况下对输入规模的增长速度&#xff0c;或者说算法执行时间的增长速度。用大写字母O和一个函数来表示&#xff0c;定义为T(n)O(f(n))。其中&#xff0c;…

数据结构与算法—查找算法(线性查找、二分查找、插值查找、斐波那契查找)

查找算法 文章目录 查找算法1. 线性查找算法2. 二分查找算法2.1 二分查找思路分析2.2 应用实例 3. 插值查找3.1 基本原理3.2 应用实例 4. 斐波那契4.1 基本原理4.2 应用实例 5. 查找总结 在java中&#xff0c;常用的查找有四种&#xff1a; 顺序(线性)查找二分查找/折半查找插值…

使用Node.js创建接口

当使用Node.js创建接口时&#xff0c;有两种主要方式&#xff1a;使用Express框架和使用Node.js的HTTP模块。 Express框架方式&#xff1a; 总的来说&#xff0c;使用Express框架可以更快速地搭建和管理接口&#xff0c;而使用Node.js的HTTP模块则提供了更多底层控制和灵活性&…

广州华锐互动:汽车电子线束加工VR仿真培训与实际生产场景相结合,提高培训效果

随着科技的不断发展&#xff0c;虚拟现实&#xff08;VR&#xff09;技术已经逐渐渗透到各个领域&#xff0c;为企业和个人带来了前所未有的便利。在汽车制造行业中&#xff0c;线束加工作为一项关键的生产工艺&#xff0c;其质量直接影响到汽车的性能和安全。因此&#xff0c;…

基于中小微企业_个体工商户的信贷评分卡模型和用户画像(论文_专利_银行调研建模使用)

背景介绍 信用贷款是指由银行或其他金融机构向中小微企业和个体工商户提供的一种贷款产品。该贷款的特点是无需提供抵押品或担保&#xff0c;主要依据借款人的信用状况来进行评估和审批。 中小微企业和个体工商户信用贷款的申请流程相对简单&#xff0c;申请人只需要提供个人…

C++高性能服务器框架muduo,与配套书籍《Linux多线程服务端编程》解读

本章解读C开源项目 muduo 代码&#xff0c;与配套书籍《Linux多线程服务端编程》&#xff0c;均来自作者陈硕&#xff0c;是业内比较有名的大神。 目录 muduo 源码解读《Linux多线程服务端编程》笔记第1章 线程安全的对象生命周期管理第2章 线程同步精要第3章 多线程服务器的适…

【【HDMI 方块移动实验 】】

HDMI 方块移动实验 dvi_transmitter_top.v module dvi_transmitter_top(input pclk ,input sys_rst_n ,input pclk_x5 ,input video_hsync ,input video_vsync ,input …

MySQL数据库的基础概念

目录 顾名思义&#xff0c;数据库是用于存储数据的&#xff0c;那这些数据被存储在哪呢&#xff1f; 文件也能存储数据&#xff0c;那在这个基础上&#xff0c;为什么还要搞出一个数据库来存储数据呢&#xff1f; MySQL的客户端登录/退出指令、服务端的启动/关闭指令 数据…

如何查看PHP信息

创建一个 PHP 文件&#xff0c;比如 info.php&#xff0c;在其中添加以下代码&#xff1a; <?php phpinfo(); ?>访问这个文件&#xff08;例如&#xff0c;在浏览器中输入 http://localhost/info.php&#xff09;&#xff0c;它会显示 PHP 的所有配置信息。在这个页面…