当前位置: 首页 > news >正文

重生之“我打数据结构,真的假的?”--2.单链表(无习题)

在这里插入图片描述

C语言中的单链表总结

单链表是一种基础的数据结构,广泛应用于C语言编程中。它由节点组成,每个节点包含数据和指向下一个节点的指针。单链表的优点在于动态内存分配和高效的插入与删除操作。本文将详细探讨单链表的定义、基本操作、应用场景以及相关示例代码。

一、单链表的基本结构

单链表由多个节点组成,每个节点包含两部分:

  • 数据部分:存储实际数据。
  • 指针部分:指向下一个节点的指针。
    在这里插入图片描述

节点的定义

在C语言中,我们可以使用结构体来定义单链表的节点。
在这里插入图片描述

typedef struct Node {int data;               // 数据部分struct Node* next;      // 指向下一个节点的指针
} Node;

二、单链表的基本操作

1. 创建单链表

创建单链表通常需要一个头指针,用于指向链表的第一个节点。若链表为空,头指针为NULL。

Node* createList() {return NULL;  // 返回空链表
}

2. 插入节点

2.1 在头部插入

在链表的头部插入新节点是最简单的操作。我们需要创建一个新节点,并将其指向当前的头节点。

Node* insertAtHead(Node* head, int newData) {Node* newNode = (Node*)malloc(sizeof(Node)); // 动态分配内存newNode->data = newData;    // 设置新节点的数据newNode->next = head;       // 新节点指向原头节点return newNode;             // 返回新的头节点
}
2.2 在尾部插入

在尾部插入节点需要遍历链表找到最后一个节点,然后将其指针指向新节点。

Node* insertAtTail(Node* head, int newData) {Node* newNode = (Node*)malloc(sizeof(Node));newNode->data = newData;newNode->next = NULL; // 新节点的下一个指针为NULLif (head == NULL) {return newNode; // 如果链表为空,返回新节点}Node* temp = head;while (temp->next != NULL) {temp = temp->next; // 遍历到最后一个节点}temp->next = newNode; // 将最后一个节点的next指针指向新节点return head;
}

3. 删除节点

删除节点通常需要指定要删除的节点值,遍历链表找到该节点并进行删除。

Node* deleteNode(Node* head, int key) {Node* temp = head;Node* prev = NULL;// 如果头节点包含要删除的值if (temp != NULL && temp->data == key) {head = temp->next; // 更新头节点free(temp);        // 释放内存return head;}// 遍历链表查找要删除的节点while (temp != NULL && temp->data != key) {prev = temp;temp = temp->next;}// 如果未找到要删除的节点if (temp == NULL) {return head;}// 解除节点的链接并释放内存prev->next = temp->next;free(temp);return head;
}

4. 查找节点

查找节点根据值查找节点的位置。

Node* search(Node* head, int key) {Node* current = head;while (current != NULL) {if (current->data == key) {return current; // 返回找到的节点}current = current->next; // 继续遍历}return NULL; // 未找到
}

5. 遍历链表

遍历链表通常用于显示链表中的所有数据。

void traverseList(Node* head) {Node* temp = head;while (temp != NULL) {printf("%d -> ", temp->data);temp = temp->next;}printf("NULL\n"); // 显示链表结束
}

6. 反转链表

反转链表操作是将链表的指向反转,使最后一个节点变为第一个节点。

Node* reverseList(Node* head) {Node* prev = NULL;Node* current = head;Node* next = NULL;while (current != NULL) {next = current->next; // 保存下一个节点current->next = prev; // 反转指针prev = current;       // 移动prev和currentcurrent = next;}return prev; // 返回新的头节点
}

三、单链表的应用

单链表在许多场景中都有应用,包括:

  1. 动态数据存储:当数据量不固定时,链表能有效利用内存。
  2. 实现栈和队列:单链表可以轻松实现栈和队列的操作。
  3. 缓存管理:可以用于实现LRU缓存。
  4. 图的邻接表表示:链表可以表示图中节点之间的连接关系。

在这里插入图片描述

四、完整示例

下面是一个完整的单链表示例,演示了所有基本操作。

#include <stdio.h>
#include <stdlib.h>typedef struct Node {int data;struct Node* next;
} Node;Node* createList() {return NULL;
}Node* insertAtHead(Node* head, int newData) {Node* newNode = (Node*)malloc(sizeof(Node));newNode->data = newData;newNode->next = head;return newNode;
}Node* insertAtTail(Node* head, int newData) {Node* newNode = (Node*)malloc(sizeof(Node));newNode->data = newData;newNode->next = NULL;if (head == NULL) {return newNode;}Node* temp = head;while (temp->next != NULL) {temp = temp->next;}temp->next = newNode;return head;
}Node* deleteNode(Node* head, int key) {Node* temp = head;Node* prev = NULL;if (temp != NULL && temp->data == key) {head = temp->next;free(temp);return head;}while (temp != NULL && temp->data != key) {prev = temp;temp = temp->next;}if (temp == NULL) {return head;}prev->next = temp->next;free(temp);return head;
}Node* search(Node* head, int key) {Node* current = head;while (current != NULL) {if (current->data == key) {return current;}current = current->next;}return NULL;
}void traverseList(Node* head) {Node* temp = head;while (temp != NULL) {printf("%d -> ", temp->data);temp = temp->next;}printf("NULL\n");
}Node* reverseList(Node* head) {Node* prev = NULL;Node* current = head;Node* next = NULL;while (current != NULL) {next = current->next;current->next = prev;prev = current;current = next;}return prev;
}int main() {Node* head = createList();head = insertAtHead(head, 1);head = insertAtTail(head, 2);head = insertAtTail(head, 3);head = insertAtHead(head, 0);printf("Current List: ");traverseList(head);head = deleteNode(head, 2);printf("After Deleting 2: ");traverseList(head);Node* foundNode = search(head, 1);if (foundNode) {printf("Found Node with data: %d\n", foundNode->data);} else {printf("Node not found.\n");}head = reverseList(head);printf("Reversed List: ");traverseList(head);return 0;
}

五、总结

单链表是一种灵活且实用的数据结构,通过动态内存分配和简单的插入、删除操作,使得它在许多实际应用中都能发挥重要作用。掌握单链表的基本操作,为深入学习其他数据结构奠定了基础。希望本总结对理解和使用单链表有所帮助。

小习题:

习题1

习题2

习题3

相关文章:

重生之“我打数据结构,真的假的?”--2.单链表(无习题)

C语言中的单链表总结 单链表是一种基础的数据结构&#xff0c;广泛应用于C语言编程中。它由节点组成&#xff0c;每个节点包含数据和指向下一个节点的指针。单链表的优点在于动态内存分配和高效的插入与删除操作。本文将详细探讨单链表的定义、基本操作、应用场景以及相关示例…...

【有啥问啥】视频插帧算法技术原理详解

视频插帧算法技术原理详解 引言 视频插帧&#xff08;Video Interpolation&#xff09;技术&#xff0c;作为计算机视觉领域的一项重要应用&#xff0c;旨在通过算法手段在已有的视频帧之间插入额外的帧&#xff0c;从而提升视频的帧率&#xff0c;使其看起来更加流畅。这一技…...

Leetcode148,109以及二者的合并 -> Tencent面试算法题 - 无序双向链表转BST

根源简述 这道题是腾讯在2024/8/30考的一道面试题&#xff0c;整体来说&#xff0c;难度不大&#xff0c;就是代码量稍稍有点儿大&#xff0c;让我们一起来看一下吧 题目描述 整数无序双向链表能否转BST&#xff08;二叉搜索树&#xff09;&#xff0c;如果能&#xff0c;怎么转…...

【蓝桥杯选拔赛真题77】python计算小球 第十五届青少年组蓝桥杯python选拔赛真题 算法思维真题解析

目录 python计算小球 一、题目要求 1、编程实现 2、输入输出 二、算法分析 三、程序编写 四、程序说明 五、运行结果 六、考点分析 七、 推荐资料 1、蓝桥杯比赛 2、考级资料 3、其它资料 python计算小球 第十五届蓝桥杯青少年组python比赛选拔赛真题 一、题目要…...

获取Hive表备注

DESCRIBE EXTENDED 表名;先获取Detailed Table Information这行的data_type字段数据&#xff0c;进行正则匹配&#xff0c;拿到表备注&#xff0c;如下&#xff1a; String str ReUtil.get("parameters:\\{(?!.*?\\().*transient_lastDdlTime.*?comment(.*?)\\}&quo…...

10.30学习

一、科学计数法 C语言中的科学计数法主要用于表示非常大或非常小的浮点数&#xff0c;它遵循以下格式&#xff1a; 1. E或e表示指数&#xff1a; 科学计数法中的E或e用来表示“指数”&#xff08;Exponent&#xff09;。例如&#xff0c; 1.23e4 或 1.23E4 表示 1.23 * 10^4…...

什么是栈溢出

一、什么是栈溢出 栈溢出&#xff08;Stack Overflow&#xff09;就是指在程序运行过程中&#xff0c;往栈里存放的数据超过了栈所能容纳的最大容量&#xff0c;从而导致程序出现异常行为的情况。这就好比一个箱子本来只能装一定数量的物品&#xff0c;硬要往里面塞更多的东西&…...

在linux中arm-linux-gcc和/usr/bin/gcc有啥区别

在Linux中&#xff0c;arm-linux-gcc和/usr/bin/gcc都是编译器&#xff0c;但它们之间存在显著的区别&#xff0c;主要体现在编译目标、使用场景以及编译生成的二进制文件的可执行性上。而软链接则是Linux文件系统中的一种特殊文件类型&#xff0c;用于创建一个文件的别名。 a…...

常用环境部署(二十二)——MySQL的数据库迁移到另一个机器上

1、导出原数据库的数据 mysqldump -u [用户名] -p[密码] [数据库名] > database_dump.sql 命令示例&#xff1a; mysqldump -u root -p123456 wd > /opt/wd.sql 2、在新机器上创建数据库 mysql -u [用户名] -p -e "CREATE DATABASE [新数据库名]" 命令示…...

两台主机只能单方向ping通

可能性比较大的原因时ping不通的那台主机安装了个人防火墙。 在共享上网的机器中&#xff0c;出于安全考虑&#xff0c;大部分主机都安装个人防火墙软件。几乎所有个人防火墙软件默认不允许其他机器ping本机。一般的做法是将来自外部的ICMP请求报文滤掉&#xff0c;对本机出去的…...

redis windows 5.0 下载

Redis 简介 Redis 是一个高性能的 key-value 数据库&#xff0c;广泛应用于缓存、消息队列、实时分析等场景。它支持多种数据结构&#xff0c;如字符串、哈希、列表、集合、有序集合等&#xff0c;并且提供了丰富的操作命令&#xff0c;能够满足各种复杂的数据处理需求。 下载…...

视频转gif怎么转换?6种视频格式转换简单方法分享,附操作截图!

gif动图凭借其简洁而生动的特点&#xff0c;已成为互联网交流中不可或缺的一部分。尽管gif和视频在技术上有所不同&#xff0c;但两者都能以短小的帧展现动作&#xff0c;而gif通常不带声音&#xff0c;具备循环播放的特性。因此&#xff0c;出于创建gif动图、存储更多媒体文件…...

StructRAG简介

StructRAG是一种新型的框架&#xff0c;旨在提升大型语言模型&#xff08;LLMs&#xff09;在知识密集型推理任务中的性能。它通过推理时的混合信息结构化机制&#xff0c;根据任务需求以最合适的格式构建和利用结构化知识。 以下是StructRAG的核心组成部分和工作流程&#xff…...

java脚手架系列12-mongoDB

之所以想写这一系列&#xff0c;是因为之前工作过程中有几次项目是从零开始搭建的&#xff0c;而且项目涉及的内容还不少。在这过程中&#xff0c;遇到了很多棘手的非业务问题&#xff0c;在不断实践过程中慢慢积累出一些基本的实践经验&#xff0c;认为这些与业务无关的基本的…...

python四舍五入保留两位小数

在 Python 中&#xff0c;你可以使用内置的 round() 函数来对数字进行四舍五入并保留两位小数。round() 函数有两个参数&#xff1a;要四舍五入的数字和要保留的小数位数。以下是一个简单的示例&#xff1a; # 示例数字 number 3.14159# 四舍五入保留两位小数 rounded_number…...

期权懂|有什么期权交易策略能够稳赚不赔的?

期权小懂小编每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 有什么期权交易策略能够稳赚不赔的? 期权交易具有风险性&#xff0c;没有任何一种策略能够保证稳赚不赔。 以下是一些常见的期权交易策略&#xff0c;虽不能保证盈利&#…...

笔记本脱机状态

先是显示脱机&#xff0c;请尝试其他方法登录 1.按照联想客服&#xff0c;进入高级选项里面&#xff0c;清除两个更新项目&#xff0c;没有卸载成功 2.安装wepe&#xff0c;先是能检测到U盘&#xff0c;但是进不去&#xff0c;然后我淘宝淘帮我做盘&#xff0c;我自己重新装了一…...

Node.js:模块 包

Node.js&#xff1a;模块 & 包 模块module对象 包npm安装包配置文件镜像源 分类 模块 模块化是指解决一个复杂问题时&#xff0c;自顶向下逐层把系统划分成若干模块的过程。对于整个系统来说&#xff0c;模块是可组合、分解和更换的单元。 简单来说&#xff0c;就是把一个…...

油动无人机动力测试台-60公斤级-Flight Stand 60 ICE

产品简介 通过Flight Stand 60 ICE测试台对内燃机和螺旋桨的拉力&#xff0c;扭矩&#xff0c;转速&#xff0c;燃油流量&#xff0c;温度&#xff0c;功率和螺旋桨效率的测量&#xff0c;帮助用户精准地描述和评估其性能参数&#xff0c;以不断地优化和提升燃油动力系统性能。…...

给grasshopper中的python脚本电池加个标签

ghenv.Component.Message test使用python脚本创建的电池&#xff0c;也可以保存起来。 File – Create User Object...

2026届学术党必备的六大AI写作方案横评

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek DeepSeek身为先进的大语言模型&#xff0c;能够为学术论文写作给予系统性辅助。研究者理应首…...

03_Neo4j知识体系之5.x与2026.x新特性和版本演进

03_Neo4j知识体系之5.x与2026.x新特性和版本演进 体系 版本演进层&#xff1a;Neo4j 5.x LTS、2025/2026 日历化版本、Cypher 5 与 Cypher 25、Autonomous Clustering、Ops Manager、Vector Indexes、AI 能力关联能力&#xff1a;与升级迁移路径、集群扩容、Fabric 联邦查询、差…...

别再自己造轮子了!用InsightFace+FastAPI快速搭建一个高精度人脸识别Web服务

基于InsightFace的高精度人脸识别Web服务实战指南 1. 为什么选择InsightFace构建人脸识别服务 三年前我接手一个考勤系统项目时&#xff0c;曾花费两个月时间从零训练FaceNet模型&#xff0c;结果上线后遇到戴眼镜员工识别率骤降的问题。直到发现InsightFace这个开源项目&#…...

AngularJS Http详解

AngularJS Http详解 引言 AngularJS是一个流行的JavaScript框架,用于构建动态和响应式的web应用。在AngularJS中,HTTP请求是数据交互的重要组成部分。本文将详细介绍AngularJS的Http服务,包括其基本用法、高级特性以及如何处理异步请求。 AngularJS Http服务简介 Angula…...

中文分词避坑指南:Jieba与统计分词法的性能对比与优化技巧

中文分词避坑指南&#xff1a;Jieba与统计分词法的深度对比与实战优化 在自然语言处理领域&#xff0c;中文分词一直是基础却充满挑战的环节。不同于英文等以空格分隔单词的语言&#xff0c;中文文本的连续字符流特性使得准确划分词语边界成为NLP预处理的关键难题。本文将深入剖…...

Blender 3MF插件:让3D打印设计流程更智能的5个关键步骤

Blender 3MF插件&#xff1a;让3D打印设计流程更智能的5个关键步骤 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 还在为3D打印文件格式转换而烦恼吗&#xff1f;想象一…...

探索Ryujinx:在PC上免费畅玩Switch游戏的完整指南

探索Ryujinx&#xff1a;在PC上免费畅玩Switch游戏的完整指南 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx 你是否曾梦想在电脑上体验《塞尔达传说&#xff1a;王国之泪》的壮丽冒险…...

高效全能屏幕工具eSearch:从安装到精通的实用指南

高效全能屏幕工具eSearch&#xff1a;从安装到精通的实用指南 【免费下载链接】eSearch 截屏 离线OCR 搜索翻译 以图搜图 贴图 录屏 万向滚动截屏 屏幕翻译 Screenshot Offline OCR Search Translate Search for picture Paste the picture on the screen Screen recorder Omni…...

百考通:AI精准赋能期刊论文写作,让研究更顺畅

在学术研究领域&#xff0c;期刊论文的撰写是成果输出的关键环节&#xff0c;却也让众多科研工作者与学生倍感压力&#xff1a;选题迷茫、逻辑梳理困难、格式规范复杂、内容提炼耗时&#xff0c;严重拖慢了学术成果的发表节奏。百考通&#xff08;https://www.baikaotongai.com…...

E-Hentai漫画批量下载终极指南:三步实现高效资源管理

E-Hentai漫画批量下载终极指南&#xff1a;三步实现高效资源管理 【免费下载链接】E-Hentai-Downloader Download E-Hentai archive as zip file 项目地址: https://gitcode.com/gh_mirrors/eh/E-Hentai-Downloader 还在为E-Hentai漫画一页页手动保存而烦恼吗&#xff1…...