C语言实现单向链表

1.线性表

线性表可以分成两种 一种就是顺序表 也就是我们所熟知的数组 一种是今天的主角–链表
他们两者的区别在于 前者是顺序储存元素的 即数组元素的地址值是连续的
后者则是链式储存的 节点的地址值不一定连续

2.单向链表

链表中的节点是由两部分组成的 一部分是数据域 另外一部分是指针域
而且一般都是由虚拟头节点开头的 虚拟头节点的数据域储存的是链表的长度 指针域指向的是实际的头节点

#include <stdio.h> 
#include <stdlib.h>
// 定义一个节点的结构体
typedef struct Node{int data;// 数据域struct Node* next;// 指针域 由于这边还未起好别名 所以不能直接使用Node*
}Node;
// 定义一个函数 用于初始化链表
Ndoe* initList(){// 无非就是创建一个虚拟头节点 Node* list = (Node*)malloc(sizeof(Node));list->data = 0;list->next = NULL;return list;
}
// 定义一个函数 用于进行头插操作
void headInsert(Node* list, int data){// 一定要注意两个节点的指针域修改顺序 先改待插入节点的next 然后在修改虚拟头节点的nextNode* newHead = (Node*)malloc(sizeof(Node));newHead->data = data;newHead->next = list->next;list->next = newHead;// 最后别忘了更新链表的长度list->data++;
}
// 定义一个函数 用于进行尾插操作
void tailInsert(Node* list, int data){// 你不要遍历过头了 如果当前节点的下一个节点为空的话 就停止遍历操作 而不是当前节点为空才停止遍历 因为你的目的是取出尾节点 而不是NULL// 保留你的虚拟头节点 因为list会随着遍历操作的进行而改变 Node* cur = list;while(cur->next){cur = cur->next;}Node* tail = (Node*)malloc(sizeof(Node));tail->data = data;tail->next = NULL;cur->next = tail;list->data++;
}
// 定义一个函数 用于删除指定元素对应的节点(删除第一个符合条件的节点就行了) 还得通过返回值表示删除成功与否
int delete(Node* list, int data){Node* pre = list->next;Node* cur = list->next;while(cur){// 这边的循环条件有别于tailInsert的原因在于 这边需要判断所有的节点是否和指定值相同 而tailInsert目的则是获取一个链表的尾节点而已if(cur->data == data){pre->next = cur->next;free(cur);// 更新链表长度list->data--;// 我们用1表示删除成功return 1;}// 如果当前节点不符合条件的话  则继续往下进行寻找pre = cur;cur = cur->next;}// 如果循环结束以后 都没有找到指定节点的话 说明删除失败return 0;// 我们用0表示删除失败
}
void printList(Node* list){Node* cur = list->next;while(cur){printf("%d ", cur->data);cur = cur->next;}
}

测试代码如下所示:

int main() {Node* list = initList();headInsert(list, 1);headInsert(list, 2);headInsert(list, 3);headInsert(list, 4);tailInsert(list, 5);printList(list);if (delete(list, 0)) {printf("删除成功\n");}else {printf("删除失败\n");}printList(list);return 0;
}

3.删除代码的优化

如果单向链表的删除操作中 需要将指定值对应的所有节点都进行删除的话 那么需要用一下代码进行代替

int delete(Node* list, int data){// 定义一个变量 用于储存所删除元素的个数 int deleted = 0;Node* pre = list->next;Node* cur = list->next;while(cur){if(cur->data == data){pre->next = cur->next;free(cur);list->data--;// 同时需要更新deleted变量 因为后面需要通过该变量进行删除成功与否的判断deleted++;// 但是现在pre所表示的节点不会变 但是cur表示的节点需要改变 cur需要更新为pre的下一个节点cur = pre->next;}else{// 如果没有找到指定值对应的节点的话 那么就更新pre为cur 然后更新cur为当前节点的下一个节点pre = cur;cur = cur->next;}}// 然后最后直接返回deleted 如果为0 说明删除失败 如果为1的话 那么说明删除成功 并且可以从中知道被删除元素的个数return deleted;
}

测试代码如下所示:

int main() {Node* list = initList();headInsert(list, 1);headInsert(list, 1);headInsert(list, 2);headInsert(list, 3);headInsert(list, 4);tailInsert(list, 5);printList(list);int deleted = delete(list, 1);if (deleted) {printf("删除成功 并且被删除的元素个数为%d\n", deleted);}else {printf("删除失败\n");}printList(list);return 0;
}

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

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

相关文章

SQL-DQL-基础查询

&#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&#xff1a;重拾MySQL &#x1f379;文章作者技术和水平很有限&#xff0c;如果文中出现错误&am…

制造业管理者必备技能:掌握6S管理!

当今竞争激烈的制造业领域&#xff0c;为了提高效率、优化流程&#xff0c;并实现持续创新&#xff0c;制造业管理者需要掌握一种全面、系统的管理方法——6S管理。6S管理是源自于日本的精益管理方法&#xff0c;通过整理、整顿、清扫、标准化、维持和安全这六个步骤&#xff0…

监督学习 - 决策树回归(Decision Tree Regression)

什么是机器学习 **决策树回归&#xff08;Decision Tree Regression&#xff09;**是一种机器学习算法&#xff0c;用于解决回归问题。与分类问题不同&#xff0c;回归问题的目标是预测连续型变量的值&#xff0c;而不是离散的类别。决策树回归通过构建一棵决策树来进行预测。…

力扣(leetcode)第599题两个列表的最小索引总和(Python)

599.两个列表的最小索引总和 题目链接&#xff1a;599.两个列表的最小索引总和 假设 Andy 和 Doris 想在晚餐时选择一家餐厅&#xff0c;并且他们都有一个表示最喜爱餐厅的列表&#xff0c;每个餐厅的名字用字符串表示。 你需要帮助他们用最少的索引和找出他们共同喜爱的餐厅…

基于SkyEye仿真6678处理器:实现国产操作系统ReWorks仿真运行

信号处理的数据量以及实时性的要求随着嵌入式技术的发展不断提高&#xff0c;众多厂商和研究所选择多核DSP处理器芯片去替代原有的单核DSP&#xff0c;并运行嵌入式操作系统来保证信号处理的实时性以及精确性。然而受到硬件资源或者项目实施周期限制&#xff0c;软件工程师调试…

AndroidQ修改永不休眠never

1&#xff1a;修改显示列表&#xff1a; /home/roadwell/Allwinner/SDK/A133/A133_PLUS_AndroidQV1.1NEW/android/packages/apps/Settings/res/values/arrays.xml --- a/res/values/arrays.xml b/res/values/arrays.xml -48,6 48,7 <item>5 minutes</item…

Jmerer之FTP测试

1、文件上传下载测试&#xff0c;可以使用sample:FTP请求&#xff0c;当然也可以使用HTTP Request采样器中的File Upload向服务器上传文件 2、本章重点介绍FTP请求进行文件的上传下载测试&#xff0c;添加 FTP请求&#xff0c;界面主要配置如下&#xff1a; Server Name or I…

Linux 软连接ln -s

什么是文件软链接&#xff1f; Linux 的“软连接”与windos 的"快捷方式"相似。文件软链接&#xff08;Symbolic Link 或 SymLink&#xff09;是一种特殊的文件类型&#xff0c;它实际上是一个指向另一个文件或目录的引用。创建软链接时&#xff0c;系统会建立一个新…

服务器配置 ssh 密钥登录

服务器配置 ssh 密钥登录 配置 服务器安全组策略&#xff0c;开放 ssh 22 端口&#xff0c;以 root 用户登录服务器。 配置 ssh key 登录 ssh-keygen 生成公钥和私钥对 如果不需要其他设置&#xff0c;一直回车 可以在 ~/.ssh 目录下看到两个文件&#xff0c;即刚生成的私钥…

你想要的进程知识——进程替换

进程替换 一、什么是进程替换 创建一个进程后&#xff0c;pid 以及在内核中的信息保持 保持不变,但进程所执行的代码进行替换 作用 : 通过一个进程启动另外一个进程 应用场景&#xff1a; c程序 进程替换启动python.exe 二、exec函数家族 在 Linux 系统中提供了一组用于…

当天,本月,本周,近七天mysql防止全表扫描语句

当天&#xff1a; <![CDATA[ and wi.alarm_time > DATE_FORMAT(NOW(), %Y-%m-%d) and wi.alarm_time < DATE_ADD(DATE_FORMAT(NOW(), %Y-%m-%d), INTERVAL 1 day) ]]> 本月&#xff1a; <![CDATA[ and wi.alarm_time>DATE_ADD(curdate(),interval -day(curd…

访问学者申请需要注意什么?

访问学者申请是一项复杂而重要的过程&#xff0c;需要申请人在准备材料和过程中注意一些关键事项&#xff0c;以确保顺利完成申请并提高成功率。以下是知识人网小编的一些建议&#xff0c;希望对你的访问学者申请有所帮助。 1. 详细了解目标学术机构&#xff1a; 在申请访问学…

数据截取处理、富文本去除所有标签

前提&#xff1a;在做项目中有个需求是填写表单后生成一份文档&#xff0c;文档可以编辑、保存。 这部分用富文本处理了&#xff0c;涉及到的逻辑就是对象-->富文本标签形式 在给后端传的数据格式再把富文本标签形式-->对象形式。 涉及到文字&#xff0c;图片、表格&a…

SQL性能分析-整理

昨日对MySQL的索引整理了一份小文档&#xff0c;对结构/分类/语法等做了一个小总结&#xff0c;具体文章可点击&#xff1a;MySQL-索引回顾&#xff0c;索引知识固然很重要&#xff0c;但引入运用到实际工作中更重要。 参考之前的文章&#xff1a;SQL优化总结以及参考百度/CSDN…

深入探讨:开发连锁餐饮APP的关键技术要点

时下&#xff0c;开发一款功能强大、用户友好的连锁餐饮APP成为许多餐饮企业的当务之急。在本文中&#xff0c;我们将深入探讨开发连锁餐饮APP的关键技术要点&#xff0c;涵盖了前端、后端以及数据库等方面。 一、前端开发 前端是用户与APP交互的入口&#xff0c;因此设计良好…

【QT学习十一】QThread

一、引言 在现代软件开发中&#xff0c;多线程编程变得越来越重要&#xff0c;尤其是对于需要处理并发任务的应用程序。Qt C 框架提供了强大的多线程支持&#xff0c;使得开发者能够轻松地创建和管理多线程应用。 在 Qt 中&#xff0c;多线程的实现主要基于 QThread 类。QThrea…

openLDAP统一认证在nodejs或flask等web系统中的配置使用

在OA&#xff08;办公自动化&#xff09;系统中集成OpenLDAP进行统一认证&#xff0c;通常涉及以下步骤&#xff1a; 配置OpenLDAP服务器&#xff1a; 首先确保你的OpenLDAP服务器已经安装和配置好&#xff0c;并且包含组织内的用户、组以及其他必要属性。这些信息应该包括用户…

比尔盖茨:如果只能解决一个问题,我的答案总是营养不良

谷禾健康 当地时间12月19日&#xff0c;微软联合创始人、亿万富翁比尔盖茨发布了对来年的年度预测&#xff0c;称 2024 年将是一个“转折点”。 在这封长达 10 页的信中他展示了对人工智能领域的更多创新、婴儿营养不良问题的突破、气候变化谈判的进展等多方面的期待。 人工智能…

CentOS7搭建Harbor企业级Docker仓库

centos7搭建Harbor企业级docker仓库 前言 Harbor是一个企业级的Docker Registry管理项目&#xff0c;主要用于存储和分发Docker镜像。它提供了一些企业必需的功能特性&#xff0c;如安全、标识和管理等&#xff0c;以扩展开源Docker Distribution。 作为企业级私有Registry服…

【iOS】数据持久化(四)之FMDB

正如我们前面所看到的&#xff0c;原生SQLite API在使用时还是比较麻烦的&#xff0c;于是&#xff0c;开源社区就出现了一系列将SQLite API进行封装的库&#xff0c;其中FMDB的被大多数人所使用 FMDB和SQLite相比较&#xff0c;SQLite比较原始&#xff0c;操作比较复杂&#…