单链表经典oj题 (一) 简单

1.删除指定节点数据(非尾节点),要求时间复杂度为O(1)

. - 力扣(LeetCode)

在之前我们将单链表删除指定节点的操作是先遍历找到pos的前一个结点,然后再进行删除,但是现在要求再O(1)时间内完成,这就要想一种新的思路来解决这个问题了。

我们不能去遍历链表,但是我们能找到要删除的节点的下一个节点,这个题的要求是删除那个数据,并不是说要删除这个节点,那么我们就可以将要删除的节点的数据与下一个结点的数据进行调换,这样问题就转换为了删除下一个节点了,怎样处理就很简单了。

思路有了,而这个题的代码也很简单,那就直接放上答案。

void deleteNode(struct ListNode* node) {struct ListNode* next=node->next;node->val=node->next->val;node->next=node->next->next;free(next);
}

2.返回倒数第k个节点

. - 力扣(LeetCode)

看到这个题的第一个思路就是暴力求解,首先遍历一遍链表,统计节点个数 n ,然后第n+1-k个节点就是倒数第 k 个节点 。

int kthToLast(struct ListNode* head, int k){int n=0;struct ListNode* cur=head;while(cur){n++;cur=cur->next;}n=n-k+1;cur=head;while(--n)//第n个节点只要循环n-1次{cur=cur->next;}return cur->val;}

但是这个题还有一这种思路只用遍历一遍链表,我们用快慢指针来解决,首先fast先往后走k步

这时slow和fast再同时往后走,当fast为NULL的时候,slow就是倒数第k个节点

这样实现起来代码也很简单

int kthToLast(struct ListNode* head, int k){struct ListNode* fast=head;struct ListNode* slow=head;while(k--){fast=fast->next;}while(fast){fast=fast->next;slow=slow->next;}return slow->val;
}

因为题目中明确说明了k是有效的,所以我们就不用判断fast在第一个循环就走到了NULL的情况的。

掌握了上面的题,再来做一个相似的题

删除链表的倒数第N个节点,并返回新的头节点

https://leetcode.cn/problems/SLwz0R/

这个题是要删除倒数第N个节点,那我们首先要找到倒数第N+1个节点,修改这个节点的next。

这个题目中给的信息是N<=sz,这就说明有可能删除的是头节点的,所以在fast走完N步之后,要先判断fast是否已经为空,如果fast已经是NULL了,则说明要删除的是头节点。

如果这时候fast不为空,则说明要删的不是头节点,这时候fast再往前走一步,

struct ListNode* removeNthFromEnd(struct ListNode* head, int n){struct ListNode* fast=head;struct ListNode* slow=head;while(n--){fast=fast->next;}if(fast==NULL)//判断要删除的是否是头节点{head=head->next;free(slow);return head;}//不是头节点在快慢指针继续走fast=fast->next;while(fast){fast=fast->next;slow=slow->next;}struct ListNode* del=slow->next;slow->next=del->next;free(del);return head; }

3.反转链表

. - 力扣(LeetCode)

反转链表的思路就是遍历每个节点然后头插,

要注意的就是要记录cur的下一个节点的地址。

struct ListNode* reverseList(struct ListNode* head) {struct ListNode* newhead=NULL;struct ListNode* cur=head;struct ListNdoe* next=NULL;while(cur){//记录下一个节点next=cur->next;//头插cur->next=newhead;//换头newhead=cur;//迭代cur=next;}return newhead;
}

写完这段代码之后先思考一下空链表的问题,由于我们newhead初始化为NULL,如果是空链表的话,返回时的newhead也是NULLL,所以不会有问题。

4.合并两个升序链表

. - 力扣(LeetCode)

合并两个升序链表我们很容易想到在之前的数组阶段见过的合并两个升序数组,当时我们使用的是归并排序,在链表中我们同样可以用归并来合并两个链表。首先我们用一个哨兵位的头节点来接收归并后的链表,因为合并升序链表要用到尾插,我们再用一个tail来记录新链表的尾。

然后我们用两个指针来遍历两个链表,取小的尾插到新链表上去,直到cur1或者cur2指向NULL,之后再将没遍历完的链表插入到新链表后面。

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {struct ListNode* guard=(struct ListNode*)malloc(sizeof(struct ListNode));guard->next=NULL;struct ListNode* tail=guard;struct ListNode* cur1=list1;struct ListNode* cur2=list2;while(cur1&&cur2){if(cur1->val<=cur2->val){tail->next=cur1;tail=cur1;cur1=cur1->next;}else{tail->next=cur2;tail=cur2;cur2=cur2->next;}}if(cur1)//cur2遍历完了{tail->next=cur1;}else{tail->next=cur2;}struct ListNode* head=guard->next;free(guard);return head;}

5.链表相交

. - 力扣(LeetCode)

这个题我们首先要判断两个链表是否相交,判断相交不难,因为如果两个链表相交的话,他们的尾节点是相同的,所以我们可以遍历两个链表,判断两个链表的尾节点是否相同。

    if(!headA||!headB)//有一个空链表就返回NULLreturn NULL;struct ListNode* cur1=headA;struct ListNode* cur2=headB;while(cur1->next){cur1=cur1->next;}while(cur2->next){cur2=cur2->next;}if(cur1!=cur2)//不相交{return NULL;}else{//找相交节点}

我们首先判断一下两个链表是否有空链表,如果有一个是空链表或者都是空链表,则没有相交。

在判断完是否相交之后,如何去找相交的节点呢?

首先我们是可以求出两个链表的节点的个数的,也就是链表的长度,当链表相交之后后半段的长度是相等的,所以两个链表的长度差就差在相交之前的部分。

那么我们是不是可以让长的链表先走 他们的长度差 的步数,如何在两个指针一起走,这样他们相遇的节点就是相交的起始节点。

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {if(!headA||!headB)//有一个空链表就返回NULLreturn NULL;struct ListNode* cur1=headA;struct ListNode* cur2=headB;int lenA=0;int lenB=0;while(cur1->next){cur1=cur1->next;lenA++;}while(cur2->next){cur2=cur2->next;lenB++;}if(cur1!=cur2)//不相交{return NULL;}else{//找相交节点struct ListNode* longlist = (lenA>lenB?headA:headB);struct ListNode* shortlist = (lenA>lenB?headB:headA);//求出长度差int gap=abs(lenA-lenB);//长链表先走gap步while(gap--){longlist=longlist->next;}//同时走while(longlist!=shortlist){longlist=longlist->next;shortlist=shortlist->next;}return shortlist;}}

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

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

相关文章

Kubernetes有状态任务

有状态任务是指执行期间需要维护一定状态或数据的任务或工作。这些任务通常需要记录并维护数据、状态、上下文或进度信息&#xff0c;并且这些信息在任务执行期间保持持久。有状态任务的解决目标是确保任务在不同的环境、节点或时间点之间维持一致的状态和标识。这种任务通常需…

2-3 AUTOSAR ASW Runable可运行实体

返回总目录->返回总目录<- 目录 一、概述 二、RTE Event 一、概述 运行实体(Runnable Entity,RE)是一段可执行的代码,其包含实际实现的函数(具体的逻辑算法或者操作)。一个软件组件可以包含一个或者多个运行实体。 Runnable就是SWC中的函数,而在AutoSAR架构在被…

Windows Server 2012 R2安装远程桌面服务

文章目录 一、打开【服务器管理器】二、点击【添加角色和功能】三、点击【下一步】四、点击【下一步】五、点击【下一步】![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/05b61a830faf477e81f858ec00bbdfff.png)六、勾选【远程桌面服务】→点击【下一步】七、点击【…

sharo反序列化漏洞

启动docker 服务 sudo service docker start 打开靶场 sudo docker run -d -p 80:8080 medicean/vulapps:s_shiro_1 输入docker虚拟机地址打开靶机sharo框架 如何利用漏洞 打开工具目录在终端中打开 输入靶机地址 打开yaki监听端口可以设置为6666 返回工具填写靶机ip和端口 …

Windows应急响应

1.排查隐藏账号 查看注册表 找到攻击者用户目录文件 排查用户异常 eventvwr.msc 分析用户登录日志 排查可疑端口 排查可疑进程 检查启动项、计划任务和服务 查看系统补丁信息 安装火绒&#xff0c;在安全工具里有火绒剑 计划任务 使用D盾对主机进行检测&#xff0c;发现隐藏账户…

中非绿色能源合作走深走实

近日&#xff0c;第十六届非洲能源大会在南非立法首都开普敦举行&#xff0c;探讨实现非洲能源转型的可持续解决方案。近年来&#xff0c;中国与非洲国家不断加强绿色能源合作&#xff0c;促进双方优势资源互补&#xff0c;逐步探索合作共赢的绿色能源合作方案。 势头良好 近年…

【201】Java8读取JSON树形结构并插入到MySQL数据库表中

我写了一个 maven 项目的 Demo&#xff0c;用来演示 JAVA8 如何读取 JSON 文件树形结构&#xff0c;并将这种树形结构保存到 MySQL 中。 json文件 city.json {"name": "山东省","sub": [{"name": "青岛市","sub"…

什么是SYN攻击,有什么办法防御SYN攻击

自进入数字化互联网时代&#xff0c;网络技术给我们带来了许多服务&#xff0c;为人们的生活增添了许多便利。但同时&#xff0c;网络安全问题也日益凸显&#xff0c;其中DDoS攻击&#xff0c;即分布式拒绝服务攻击&#xff0c;已经成为一种常见的网络威胁。这种攻击方式通过控…

Python爬取公众号封面图(零基础也能看懂)

&#x1f4da;博客主页&#xff1a;knighthood2001 ✨公众号&#xff1a;认知up吧 &#xff08;目前正在带领大家一起提升认知&#xff0c;感兴趣可以来围观一下&#xff09; &#x1f383;知识星球&#xff1a;【认知up吧|成长|副业】介绍 ❤️感谢大家点赞&#x1f44d;&…

文献速递:深度学习胰腺癌诊断--深度学习算法用于从疾病轨迹预测胰腺癌风险

文献速递&#xff1a;深度学习胰腺癌诊断--深度学习算法用于从疾病轨迹预测胰腺癌风险 麦田医学 美好事物中转站 2024-04-02 14:36 Title 题目 A deep learning algorithm to predict risk of pancreatic cancer from disease trajectories 深度学习算法用于从疾病轨迹预测…

Redis 客户端

Redis 客户端 客户端-服务器结构 Redis 同 Mysql 一样&#xff0c;也是一个客户端-服务器结构的程序&#xff0c;结构如下图&#xff1a; 注&#xff1a;Redis 客户端和服务器可以在同一个主机上&#xff0c;也可以在不同主机上 Redis 客户端的多种形态 自带的命令行客户端&…

HTML:表单

案例&#xff1a; <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title>报名表</title> </head> <body><form action"demo/welcome.php" method"post">名字&#xff1a;<inpu…

【经典算法】LeetCode25:K 个一组翻转链表(Java/C/Python3,Hard)

#算法 目录 题目描述思路及实现方式一&#xff1a;递归思路代码实现Java 版本C 语言版本Python3 版本 复杂度分析 方式二&#xff1a;迭代和原地反转思路代码实现Java 版本C 语言版本Python3 版本 复杂度分析 总结相似题目 标签&#xff1a;链表、递归 题目描述 给你链表的头…

金融企业区域集中库的设计构想和测试验证

导读 本文探讨了金融企业区域集中库的设计构想和测试验证&#xff0c;包括架构设想、数据库整合场景测试及优势和使用设想。作者提出利用 TiDB 数据库产品集中建设区域集中库&#xff0c;解决 MySQL 存量节点的整合问题&#xff0c;实现部署的标准化、按需扩展和统一运维管理。…

阿里云4核8G服务器ECS通用算力型u1实例优惠价格

阿里云4核8G服务器优惠价格955元一年&#xff0c;配置为ECS通用算力型u1实例&#xff08;ecs.u1-c1m2.xlarge&#xff09;4核8G配置、1M到3M带宽可选、ESSD Entry系统盘20G到40G可选&#xff0c;CPU采用Intel(R) Xeon(R) Platinum处理器&#xff0c;阿里云活动链接 aliyunfuwuq…

11 flink-sql 中基于 mysql-cdc 连接 mysql-pxc 集群无法获取增量数据问题

前言 问题是来自于 群友, 2024.03.29, 也是花了一些时间 来排查这个问题 大致的问题是用 mysql-cdc 连接了一个 mysql-pxc 集群, 然后创建了一个 test_user 表 使用 "select * from test_user" 获取数据表的数据, 可以拿到 查询时的快照, 但是 无法获取到后续对…

拾光坞N3 ARM 虚拟主机 i茅台项目

拾光坞N3 在Dcoker部署i茅台案例 OS&#xff1a;Ubuntu 22.04.1 LTS aarch64 cpu&#xff1a;RK3566 ram&#xff1a;2G 部署流程——》mysql——》java8——》redis——》nginx mysql # 依赖 apt update apt install -y net-tools apt install -y libaio* # 下载mysql wg…

CSS设置字体样式

目录 前言&#xff1a; 1.font-family&#xff1a; 2.font-style&#xff1a; 3.font-weight&#xff1a; 4.font-size&#xff1a; 5.font-variant&#xff1a; 6.font&#xff1a; 前言&#xff1a; 在网页中字体是重要的组成部分&#xff0c;使用好字体可以让网页更…

[AIGC] Spring Interceptor 拦截器详解

文章目录 什么是Spring Interceptor如何使用Spring InterceptorSpring Interceptor的影响 什么是Spring Interceptor Interceptor&#xff08;拦截器&#xff09;是Spring MVC框架中的一种特性&#xff0c;类似于Servlet开发中的Filter&#xff08;过滤器&#xff09;&#xf…

Java常用函数接口

Java常用函数接口 Java 8 中引入的常用函数式接口&#xff0c;也就是 java.util.function 包中的接口。这些接口提供了一种简洁的方式来定义函数&#xff0c;常用于 Lambda 表达式和方法引用。下面是一些常用的接口&#xff1a; 一、Predicate&#xff08;断言&#xff09; …