【LeetCode】【数据结构】单链表OJ常见题型(二)

 👀樊梓慕:个人主页

 🎥个人专栏:《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》

🌝每一个不曾起舞的日子,都是对生命的辜负


目录

前言:

【LeetCode】面试题02.04. 分割链表

【LeetCode】160. 相交链表

【LeetCode】141. 环形链表

【LeetCode】142. 环形链表Ⅱ

方法一

方法二 


前言:

本系列博文博主会讲解链表的经典OJ题目。

欢迎大家📂收藏📂以便未来做题时可以快速找到思路,巧妙的方法可以事半功倍。

=========================================================================

GITEE相关代码:🌟fanfei_c的仓库🌟

=========================================================================

【LeetCode】面试题02.04. 分割链表

原题链接:🍏分割链表🍏

题目:给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。

你不需要 保留 每个分区中各节点的初始相对位置。

本题使用带头结点的单链表更为简单,可以免去极端情况的判断(全大于等于x或全小于x)以及连接两个链表时的麻烦。

所以我们直接申请两个哨兵结点。

  • 令小于x的尾插到lead的链表上;
  • 令大于或等于x的尾插到ghead的链表上。

最后连接两个链表即可。

代码实现: 

struct ListNode* partition(struct ListNode* head, int x)
{struct ListNode* ghead,*gtail,*lhead,*ltail;struct ListNode* cur=head;ghead=gtail=(struct ListNode*)malloc(sizeof(struct ListNode));lhead=ltail=(struct ListNode*)malloc(sizeof(struct ListNode));while(cur){if(cur->val<x){ltail->next=cur;// 尾插ltail=ltail->next;}else{gtail->next=cur;// 尾插gtail=gtail->next;}cur=cur->next;}gtail->next=NULL;// 不置空 会导致链表进入循环ltail->next=ghead->next;// 连接两个链表struct ListNode* newhead=lhead->next;// 保存返回值,以便释放与返回free(lhead);free(ghead);return newhead;
}

【LeetCode】160. 相交链表

原题链接:🍏相交链表🍏

题目:给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。

该题可以利用差距步的方法,首先计算两个链表的长度,利用该长度差让长的链表先走差距步。

再同时向后走,当两个指针相等时,该位置即为交点。

代码中的假设法是一种非常值得学习的方法,大家可以自行领悟,我在代码中标识出来了。

代码实现:

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) 
{struct ListNode* curA=headA;struct ListNode* curB=headB;int numA=1;int numB=1;while(curA->next)// 题目给定链表不为空,且两个循环结束后我们需要利用cur指针来判断是否相交,所以这里采用cur->next来判断结束{curA=curA->next;numA++;// 由于上面循环结束条件为cur->next为空,所以这里的值少1。因此我们定义num的值为1}while(curB->next)// 同上{curB=curB->next;numB++;// 同上}if(curA!=curB)// 不相交{return NULL;}struct ListNode* longList=headA,*shortList=headB;int gap=abs(numA-numB);// 计算差距步,abs绝对值函数if(numA<numB)// 假设法{longList=headB;shortList=headA;}while(gap--)// 令longList走差距步{longList=longList->next;}while(longList!=shortList){longList=longList->next;shortList=shortList->next;}return longList;
}

【LeetCode】141. 环形链表

原题链接:🍏环形链表🍏

题目:给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

快慢指针法: 

定义两个指针。

  • 一个名为slow,slow每次走一步;
  • 一个名为fast,fast每次走两步。

当fast或者fast->next不为空时持续进行指针移动。

如果该链表为环形链表,那么一定存在某一时刻slow与fast相等,返回true;

如果跳出循环证明链表为非环形链表。

代码实现:

bool hasCycle(struct ListNode *head) 
{struct ListNode* slow=head;struct ListNode* fast=head;while(fast && fast->next){slow=slow->next;fast=fast->next->next;if(slow==fast)return true;}return false;
}

 【LeetCode】142. 环形链表Ⅱ

原题链接:🍏环形链表Ⅱ🍏

题目:给定一个链表的头节点  head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null

方法一

与上面的思路相同,同样需要首先找到快慢指针相遇的时刻。

因为slow在一圈内必然fast会与其相遇,所以设slow在环内走了X距离。

设环外链表长度L,环的周长为C,slow进环时fast已经走了n圈,fast走的距离是slow走的距离的二倍,我们可以得到2(L+X)=L+n*C+X,即L=(n-1)*C+C-X。

如图:

结论:一个指针在相遇点meet,另一个指针为头指针,两指针同时移动,会在入环点相遇。

代码实现: 

struct ListNode* detectCycle(struct ListNode* head)
{struct ListNode* slow = head;struct ListNode* fast = head;while (fast && fast->next){slow = slow->next;fast = fast->next->next;if (slow == fast){struct ListNode* meet = slow;while (head != meet){meet = meet->next;head = head->next;}return head;}}return NULL;
}

 方法二 

还记得上面的题目相交链表么?

我们可以将该环在相遇点meet处断开,再执行判断相交链表的函数即可。

代码实现:

//相交链表
struct ListNode* getIntersectionNode(struct ListNode* headA, struct ListNode* headB)
{struct ListNode* curA = headA;struct ListNode* curB = headB;int numA = 1;int numB = 1;while (curA->next)// 题目给定链表不为空,且两个循环结束后我们需要利用cur指针来判断是否相交,所以这里采用cur->next来判断结束{curA = curA->next;numA++;// 由于上面循环结束条件为cur->next为空,所以这里的值少1。因此我们定义num的值为1}while (curB->next)// 同上{curB = curB->next;numB++;// 同上}if (curA != curB)// 不相交{return NULL;}struct ListNode* longList = headA, * shortList = headB;int gap = abs(numA - numB);// 计算差距步,abs绝对值函数if (numA < numB)// 假设法{longList = headB;shortList = headA;}while (gap--)// 令longList走差距步{longList = longList->next;}while (longList != shortList){longList = longList->next;shortList = shortList->next;}return longList;
}//环形链表Ⅱ
struct ListNode* detectCycle(struct ListNode* head)
{struct ListNode* slow = head;struct ListNode* fast = head;while (fast && fast->next){slow = slow->next;fast = fast->next->next;if (slow == fast){struct ListNode* meet = slow;struct ListNode* newhead = meet->next;meet->next = NULL;return getIntersectionNode(head, newhead);}}return NULL;
}

快慢指针法是链表解题思路中非常常见的一种方法,博主在该系列博文的上一篇文章中也利用了该种方法,可以供大家整理参考,消化思路。

链接在这👉【LeetCode】【数据结构】单链表OJ常见题型(一)👈


=========================================================================

如果你对该系列文章有兴趣的话,欢迎持续关注博主动态,博主会持续输出优质内容

🍎博主很需要大家的支持,你的支持是我创作的不竭动力🍎

🌟~ 点赞收藏+关注 ~🌟

========================================================================= 

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

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

相关文章

微信小程序申请步骤

微信公众平台链接&#xff1a;https://mp.weixin.qq.com/ 1、进到微信公众平台&#xff0c;点一下“点击注册”&#xff0c;挑选账号申请种类“小程序”&#xff0c;填好微信小程序用户信息&#xff0c;包含电子邮箱、登陆密码等。 2、微信公众平台会发送一封电子邮件&#xf…

Android WebView简单应用:构建内嵌网页浏览功能

在现代移动应用开发中&#xff0c;内嵌网页浏览功能是许多应用程序的常见需求。Android平台提供了WebView组件&#xff0c;它允许开发者将网页内容嵌入到应用中&#xff0c;并提供了丰富的功能和定制选项。本文将介绍如何在Android应用中使用WebView组件&#xff0c;帮助您快速…

Web3 solidity编写交易所合约 编写ETH和自定义代币存入逻辑 并带着大家手动测试

上文 Web3 叙述交易所授权置换概念 编写transferFrom与approve函数我们写完一个简单授权交易所的逻辑 但是并没有测试 其实也不是我不想 主要是 交易所也没实例化 现在也测试不了 我们先运行 ganache 启动一个虚拟的区块链环境 先发布 在终端执行 truffle migrate如果你跟着我…

# ⛳ Docker 安装、配置和详细使用教程-Win10专业版

目录 ⛳ Docker 安装、配置和详细使用教程-Win10专业版&#x1f69c; 一、win10 系统配置&#x1f3a8; 二、Docker下载和安装&#x1f3ed; 三、Docker配置&#x1f389; 四、Docker入门使用 ⛳ Docker 安装、配置和详细使用教程-Win10专业版 &#x1f69c; 一、win10 系统配…

ArcGIS Pro基础:【划分】工具实现等比例、等面积、等宽度划分图形操作

本次介绍【划分】工具的使用&#xff0c;如下所示&#xff0c;为该工具所处位置。使用该工具可以实现对某个图斑的等比例面积划分、相等面积划分和相等宽度划分。 【等比例面积】&#xff1a;其操作如下所示&#xff0c;其中&#xff1a; 1表示先选中待处理的图斑&#xff0c;2…

python的条件判断中的not、is、is not、is not None、is None

目录 1.not A 2.is和is not 3.is not None和is None 4.实例 1.not A 是判断A是否为0、False、空字符串、空列表、空字典、空元组以及None&#xff0c;满足任一条件即返回True 2.is和is not 是不是某种对象 3.is not None和is None None&#xff1a;在Python中是一个单…

【Linux进程篇】进程概念(2)

【Linux进程篇】进程概念&#xff08;2&#xff09; 目录 【Linux进程篇】进程概念&#xff08;2&#xff09;进程状态Linux对进程的说法linux中的信号 进程状态查看Z(zombie)——僵尸进程僵尸进程的危害 孤儿进程 进程优先级基本概念查看系统进程PRI &#xff08;优先级priori…

redis五大类型分析--list(1)

此篇为对redis五大数据类型中list的分析&#xff0c;希望能有所帮助 List API listTypePush函数 void listTypePush(robj *subject, robj *value, int where) {/* 检查编码类型是否为 quicklist (快速列表) */if (subject->encoding OBJ_ENCODING_QUICKLIST) {/* 根据参数…

vue3集成echarts最佳实践

安装 echarts npm install echarts --save 两种引用方式 非虚拟 dom import * as echarts from echarts;var chartDom document.getElementById(mychart); var myChart echarts.init(chartDom); var option;option {title: {text: Referer of a Website,subtext: Fake Da…

在java中操作redis_Data

1.引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency> 2.配置Redis数据源 redis:host: ${sky.redis.host}port: ${sky.redis.port}password: ${sk…

快速引流推广,快速引流推广策略分享,教你精准引流

科思创业汇 大家好&#xff0c;这里是科思创业汇&#xff0c;一个轻资产创业孵化平台。赚钱的方式有很多种&#xff0c;我希望在科思创业汇能够给你带来最快乐的那一种&#xff01; 在当今互联网的快速发展中&#xff0c;短视频脱颖而出&#xff0c;成为互联网的新秀&#xf…

用python做一个小游戏代码,用python制作一个小游戏

大家好&#xff0c;小编来为大家解答以下问题&#xff0c;如何用python编写一个简单的小游戏&#xff0c;用python做一个小游戏代码&#xff0c;今天让我们一起来看看吧&#xff01; 今天呢&#xff0c;给大家展示一下Python有趣的小地方&#xff0c;展示给大家看看&#xff0c…

Ansible Playbook快速部署一主多从MySQL集群

部署目标&#xff1a; 1、快速部署一套一主两从的mysql集群 2、部署过程中支持交互式定义安装目录及监听端口号 部署清单目录结构&#xff1a; rootmaster:/opt/mysql# tree . . ├── group_vars │ └── all.yml ├── hosts ├── mysql.yml └── roles└── mys…

Client-go操作Deployment

在工作中需要对kubernetes进行自定义资源的开发&#xff0c;操作K8s的资源肯定是必不可少的。K8s原生语言是用Go编写的&#xff0c;所以在CRD中使用client-go来操作资源。本次介绍一下使用client-go来操作Deployment。 1. 创建main函数 func main() {homePath : homedir.Home…

php实现登录的例子

界面&#xff1a; 登录界面login.html代码&#xff1a; <!DOCUMENT html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns"http://www.w3.org/1999/xhtml"…

ARM微架构

一、流水线 二、指令流水线 指令流水线 指令流水线 指令流水线 ARM指令流水线 ARM7采用3级流水线 ARM9采用5级流水线 Cortex-A9采用8级流水线 注1&#xff1a;虽然流水线级数越来越多&#xff0c;但都是在三级流水线的基础上进行了细分 PC的作用&#xff08;取指&#xff09; …

C#图像均值和方差计算实例

本文展示图像均值和方差计算实例,分别实现RGB图像和8位单通道图像的计算方法 实现代码如下: #region 方法 RGB图像均值 直接操作内存快/// <summary>/// 定义RGB图像均值函数/// </summary>/// <param name="bmp"></param>/// <retur…

flutter开发实战-video_player视频播放功能及视频缓存

flutter开发实战-video_player视频播放功能及视频缓存 最近开发过程中video_player播放视频&#xff0c; 一、引入video_player 在pubspec.yaml引入video_player video_player: ^2.7.0在iOS上&#xff0c;video_player使用的是AVPlayer进行播放。 在Android上&#xff0c;…

python-docx常用方法总结

由于最近有任务需要自动生成word报告&#xff0c;因此学习了一些python-docx的使用方法&#xff0c;在此总结。 目前网上相关的资料不算太多&#xff0c;且大多数都很简单。有一些稍微复杂的需求往往找不到答案&#xff0c;很多想要的方法这个库似乎并没有直接提供。在git上看…

uniapp获取屏幕宽度时 获取不到移动设备中内容盒子宽度

首先 &#xff1a;我使用的是uniapp vue3语法&#xff1a; 问题&#xff1a; 我出现这个问题是IOS 设备发现的&#xff0c;data.boxWidth为0 代码&#xff1a; const initCreated () > {const query uni.createSelectorQuery().in(instance.proxy);const el query.select…