天下三分明月夜,独有快慢指针法(链表面试题篇)

2024-03-30 15:12

本文主要是介绍天下三分明月夜,独有快慢指针法(链表面试题篇),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本篇会加入个人的所谓‘鱼式疯言’

❤️❤️❤️鱼式疯言:❤️❤️❤️此疯言非彼疯言
而是理解过并总结出来通俗易懂的大白话,
小编会尽可能的在每个概念后插入鱼式疯言,帮助大家理解的.
🤭🤭🤭可能说的不是那么严谨.但小编初心是能让更多人能接受我们这个概念 !!!请添加图片描述

前言

本篇文章是小编 刷题篇 的开篇鼻祖, 想要学好编程,小伙们的刷题是必不可少的,这次小编更重磅出击,以 “鱼式疯言”动图 的形式带着小伙们更好的理解我们解题方法是过程

主要内容是讲解我们 快慢指针 这个解题方法对于某些链表题型的堪称秒杀的存在 💥 💥 💥

下面就让充满知识双眼的宝子们一起来瞧瞧呗 💖 💖 💖

特此声明在本系列文章中将以面试题为载体展开解题方法的实际运用的(题目来源于力扣或牛客刷题网站)

目录

  1. 寻找链表的中间结点

  2. 判断链表是否带环

  3. 返回链表倒数第k个节点

一. 寻找链表的中间结点

寻找链表的中间结点题目链接

1. 题目描述

在这里插入图片描述

2. 解题思路

看到此题,小伙伴的第一想法肯定是 遍历链表长度,然后进行在走一半的长度即可到达我们的中间节点

但小编的这里有个独特的解法就是我们的双指针法

如果 节点数是奇数时

请添加图片描述

如果 节点数是偶数时

请添加图片描述

这个就是我们的快慢指针法,简单说明下就是,

先让 fast指针先走两步,然后slow指针走一步

快指针走到下一个节点或者是自身是null时,slow指针的位置就是我们的中间节点

3. 题解代码(Java)

class Solution {public ListNode middleNode(ListNode head) {if(head==null) {return head;}ListNode cur=head,prev=head;while(cur != null && cur.next != null) {prev=prev.next;cur=cur.next.next;}return prev;}
}

在这里插入图片描述

为啥我们的一个走两步,一个走一步就能找到中间的节点呢 ? ? ?

这其实是一个 数学问题

在这里插入图片描述

鱼式疯言

细节注意

cur != null && cur.next != null

这两个条件可以交换 顺序不 ,答案是 不可以的

如果交换了

cur=null 时就会造成 cur.next 空异常

而我们的正常顺序时

cur != null 时会造成短路就不引起后面的 空指针异常

二. 判断链表是否带环

判断链表是否带环题链接

1. 题目描述

在这里插入图片描述

2. 解题思路

小伙伴们可以思考一个问题,我们当我们的 节点往后走 ,那怎么找到他们 重合的位置呢

请添加图片描述

是的,这里我们还是用到了快慢指针的方法

当 fast 指针走二步, slow 指针走一步时,利用他们俩相差一步的距离就可找到重复的节点,从而重合

3.题解代码

public class Solution {public boolean hasCycle(ListNode head) {if(head==null) {return false;}ListNode slow=head;ListNode fast=head;while(fast != null && fast.next != null) {fast=fast.next.next;slow=slow.next;if(fast== slow) {return true;}}return false;}
}

在这里插入图片描述

详细说明下

快慢指针,即慢指针一次走一步,快指针一次走两步,两个指针从 链表起始位置 开始运行

如果链表带环则一定会在 环中相遇,否则快指针率先走到 链表的末尾

鱼式疯言

如果我们这样考虑是否可以呢

如果 fast 走三步,slow走一步 会发生什么呢

请添加图片描述

很明显两者是不能相遇的

所以小编的建议是 用 fast 走两步 ,slow走一步 来 解题更妥当 ❣️ ❣️ ❣️

三. 返回链表倒数第k个节点

返回链表倒数第k个节点题目链接

1. 题目描述

在这里插入图片描述

2. 解题思路

还是运用快慢指针的思路:

先让fast 走 k-1 步 ,然后再 在 fast 和 slow 指针一起走 ,直到快指针的 next 为 null

请添加图片描述

3. 题解代码

class Solution {public int kthToLast(ListNode head, int k) {ListNode slow=head,fast=head;int i=0;while(fast != null) {if(i<k) {fast=fast.next;i++;} else {fast=fast.next;slow=slow.next;}}if(i<k || k<0) {return -1;}return slow.val;}}

在这里插入图片描述
小伙伴们有思考过这背后的原理是什么么?

是的,让快指针走 k-1 是形成路程差,再一起走的时候,他们的位移差不就是倒数第k个了嘛 💥 💥 💥

总结

在本篇文章中

  1. 寻找链表的中间结点: 用快慢指针的速度差解决中点问题的理解

  2. 判断链表是否带环: 因为环,快慢直接总会一点一点相遇的快慢指针的熟悉

  3. 返回链表倒数第k个节点: 更扩展了,快慢指针也不一定先一起走,也有可能快指针先走,慢指针再跟着的思想

如果觉得小编写的还不错的咱可支持 三连 下 (定有回访哦) , 不妥当的咱请评论区 指正

希望我的文章能给各位宝子们带来哪怕一点点的收获就是 小编创作 的最大 动力 💖 💖 💖

在这里插入图片描述

这篇关于天下三分明月夜,独有快慢指针法(链表面试题篇)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/861827

相关文章

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

利用结构体作为函数参数时结构体指针的定义

在利用结构体作为函数的参数进行传递时,容易犯的一个错误是将一个野指针传给函数导致错误。 #include <stdio.h>#include <math.h>#include <malloc.h>#define MAXSIZE 10typedef struct {int r[MAXSIZE]; //用于存储要排序的数组,r[0]作为哨兵或者临时变量int length;

isa指针的理解

D3实例isa指向D3类对象。D3类的话isa指向D3元类对象。D3元类保存类中的方法调度列表,包括类方法和对象方法

C/C++语言基础知识 之 引用和指针

关于引用 引入是C++引入的新语言特性。 1 int &rn = a;-----------------------------------------------2 int* p = &a;3 int* &pa = p;4 (*pa)++;5 pa = &b;6 (*pa)++; L1:声明rn为变量a的一个引用,不需要为rn另外开辟内存单元。rn和a占

《三国:谋定天下》成为了SLG游戏现象级的成功案例

原标题:《三国:谋定天下》引领SLG游戏新潮流,B站股价五个飙升了30%   易采游戏网6月23日:B站作为年轻人喜爱的文化社区和视频平台,再次用一款新的游戏证明了其在游戏发行领域的独到眼光与强大实力。最近大火的策略角色扮演游戏《三国:谋定天下》成为了现象级的成功案例,不仅游戏本身质量受到认可,而且在竞争激烈的iOS畅销榜上勇夺第三的位置,仅排在了资深巨头DNF手游和《王者荣耀》之后。更加引人注

22.智能指针(下)

标题 五、引用计数智能指针5.1 共享引用计数智能指针共享数据5.2 使用Box定义三个共享链表5.3 使用Rc代替Box5.4 引用计数增加实验 六、RefCell和内部可变性模式6.1 通过RefCell在运行时检查借用规则6.2 内部可变性:不可变值的可变借用1)内部可变性的用例:mock对象2)创建测试场景 6.3 RefCell在运行时记录借用6.4 结合Rc和RefCell拥有多

一级指针域二级指针的函数参数传递

预备知识: 函数参数的传递问题(一级指针和二级指针)  原以为自己对指针掌握了,却还是对这个问题不太明白。请教!   程序1:   void  myMalloc(char  *s)  //我想在函数中分配内存,再返回   {        s=(char  *)  malloc(100);   }     void  main()   {        char  *p=NULL;

Python-算法编程100例-前缀和双指针(入门级)-最长的指定瑕疵度的元音子串

题目描述: 元音字符为“aeiouAEIOU” 给定一个字符串,求字符串中满足指定瑕疵度的最长元音子串的长度。元音子串为字符串中开头和结尾都是元音字符的字符串,瑕疵度为子串中非元音字符的个数。 题目分析: 1、直接使用双指针,难度稍微有些大,边界不好处理。 2、使用前缀和+双指针,题目难度简化。 瑕疵度k=0原始字符串asdbuiodevauufgh元音字符到起始位置的瑕疵度00003

C/C++语言void及void指针深层探索----笛风读书笔记系列

读书笔记系列之:c语言数据结构链表源代码                                                                               笛风                                                                               2013.10.14