单链表算法实战:解锁数据结构核心谜题——移除链表元素

embedded/2025/1/23 20:08:23/

题目如下:

在这里插入图片描述

解题过程如下:

给了链表的头结点head就相当于知道了整个链表

思路1:查找值为val的结点并返回结点位置,删除pos位置的结点。
涉及循环的嵌套,时间复杂度为O(n^2):
在这里插入图片描述
思考时间复杂度可不可以降为O(n)呢?

思路2:创建新链表,将原链表中值不为val的结点拿下来尾插。
在原链表中修改,涉及到遍历、删除,时间复杂度不太好,那就创建一个新链表,这里并没有申请一个新链表、新结点,而是创建了一个空链表,该链表里有两个指针newHeadnewTail,这两个指针还是指向原链表中的结点,通过修改两个新指针的指向来变成一个新的链表

在这里插入图片描述

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) {//创建空链表ListNode* newHead, *newTail;newHead = newTail = NULL;//查找值不为val的结点并拿下来尾插ListNode* pcur = head;while (pcur){if (pcur->val != val){//链表为空if (newHead == NULL){newHead = newTail = pcur;}//链表不为空else{newTail->next = pcur;newTail = newTail->next;}}pcur = pcur->next;}return newHead;
}

点击运行发现Case1“解答错误”:
在这里插入图片描述
OJ代码有bug怎么办?VS调试技能用起来:

//test.c
struct ListNode{int val;struct ListNode *next;};typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) {//创建空链表ListNode* newHead, * newTail;newHead = newTail = NULL;//查找值不为val的结点并拿下来尾插ListNode* pcur = head;while (pcur){if (pcur->val != val){//链表为空if (newHead == NULL){newHead = newTail = pcur;}//链表不为空else{newTail->next = pcur;newTail = newTail->next;}}pcur = pcur->next;}return newHead;
}
int main()
{//手动构造一个链表SLTNode* node1 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node2 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node3 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node4 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node5 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node6 = (SLTNode*)malloc(sizeof(SLTNode));SLTNode* node7 = (SLTNode*)malloc(sizeof(SLTNode));node1->data = 1;node2->data = 2;node3->data = 6;node4->data = 3;node5->data = 4;node6->data = 5;node7->data = 6;node1->next = node2;node2->next = node3;node3->next = node4;node4->next = node5;node5->next = node6;node6->next = node7;node7->next = NULL;SLTNode* plist = node1;int val = 6;ListNode* newHead = removeElements(plist, val);return 0;
}

在这里插入图片描述

最后发现问题所在:存储数据5的尾结点的指针域指向存储6的结点,应该把链表的尾结点的next指针置为空。

在这里插入图片描述

我们发现修改后点击运行还是会出现错误,是因为当这个链表是空链表时,不进入循环,newTail是空指针,newTail->next就是对空指针的解引用操作,这不符合语法规则,所以会报错:

在这里插入图片描述

完整代码如下:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
typedef struct ListNode ListNode;
struct ListNode* removeElements(struct ListNode* head, int val) {//创建空链表ListNode* newHead, *newTail;newHead = newTail = NULL;//查找值不为val的结点并拿下来尾插ListNode* pcur = head;while (pcur){if (pcur->val != val){//链表为空if (newHead == NULL){newHead = newTail = pcur;}//链表不为空else{newTail->next = pcur;newTail = newTail->next;}}pcur = pcur->next;}if (newTail)newTail->next = NULL;return newHead;
}

http://www.ppmy.cn/embedded/156391.html

相关文章

三天急速通关JAVA基础知识:Day3 基础加强

三天急速通关JAVA基础知识:Day3 基础加强 0 文章说明1 接口2 函数式编程2.1 Lambda表达式2.2 方法引用 3 异常3.1 异常的定义3.2 异常的分类3.2.1 检查型异常(Checked Exception)3.2.2 非检查型异常(Unchecked Exception&#xff…

python如何导出数据到excel文件

python导出数据到excel文件的方法: 1、调用Workbook()对象中的add_sheet()方法 wb xlwt.Workbook() ws wb.add_sheet(A Test Sheet) 2、通过add_sheet()方法中的write()函数将数据写入到excel中,然后使用save()函数保存excel文件 ws.write(0, 0, 1234…

GeekHour

Linux Linux的是类Unix系统,作者是Linus,也是git的作者。符合GPL(General Public License)就可以Linux的使用、修改、再发布。 Linux四部分: 内核:驱动、内存管理、进程管理、文件系统、网络协议栈…。作…

【玩转全栈】----Django模板的继承

先赞后看,养成习惯!!! 目录 模板继承的好处 模板继承的语法规则 更新代码 上文中的部门管理页面: 【玩转全栈】----Django制作部门管理页面-CSDN博客 大家会发现,由于定义了多个html文件,多个ht…

ElasticSearch是什么?基于Lucene的,那么为什么不是直接使用Lucene呢?

目录 ElasticSearch概述 Lucene与ElasticSearch的关系 为什么不直接使用Lucene 一个ES和数据库的对比 ElasticSearch是一个分布式的、开源的、实时的搜索和分析引擎,它是基于Apache Lucene构建的,旨在提供快速、可扩展、高性能的搜索解决方案。以下是对ElasticSearch及其…

graylog~认识一下-日志管理平台

1、介绍 Graylog 是一个开源的日志管理和分析平台,旨在帮助企业集中收集、存储、搜索和分析来自各种来源的日志数据。它提供了强大的实时日志处理能力,适用于大规模分布式系统和复杂的生产环境。 主要功能 集中化日志管理: 收集来自不同来源…

MongoDB的索引与聚合

一、实验目的 1. 理解索引的概念及其在MongoDB中的重要性和作用。 2. 学习如何选择适合建立索引的字段。 3. 掌握如何创建、删除索引以及如何强制使用索引。 4. 熟悉MongoDB的聚合框架和MapReduce工具,以及简单聚合命令的使用。 二、实验环境准备 1. JAV…

云原生前端开发:打造现代化高性能的用户体验

引言:前端开发的新风向 在过去的几年中,前端开发领域经历了快速的演变,从早期的静态网页到如今复杂的单页应用(SPA),再到微前端架构和渐进式Web应用(PWA),前端技术一直处…