链表中快慢指针的应用

news2024/12/23 22:08:33

目录

一、链表的中间结点

二、回文链表

三、链表中倒数第K个结点

四、删除链表的倒数第n个结点 


一、链表的中间结点

给定一个头结点为 head 的非空单链表,返回链表的中间结点。 如果有两个中间结点,则返回第二个中间结点。

 先设置两个low和fast都指向head的结点。

 现在是寻找中间结点,可以让fast一下子走两个结点,low走一个结点,两点同时向前进。

 当走到这儿的时候,会发现fast不能再继续走两步了,二low此时就是整个链表的中间结点。

这并不是一个巧合,此时就相同的时间t内,low的速度成为v,fast指针的速度为2v,low走了vt,fast走了2vt==链表长度,所以low走过的长为链表长度的一半,就是中间位置。所以整个循环的种植条件就是fast != null && fast.next != null,只要fast还能继续向后走,low就不是中间位置。

这种方法可以用来寻找链表的任意位置。

    public ListNode middleNode(ListNode head) {
        ListNode low = head;
        ListNode fast = head;
        while(fast != null && fast.next != null){
            fast = fast.next.next;
            low = low.next;
        }
        return low;
    }

二、回文链表

给你一个单链表的头节点 head ,请你判断该链表是否为回文链表。如果是,返回 true ;否则,返回 false 。

回文链表问题 = 反转链表 + 找到链表中间结点问题。

当我们已经找到中间结点mid时,把mid当做头结点,将剩下的链表反转称为l2,再与以head为头结点的链表遍历进行比较,所以这个时候循环的终止条件就是l2!=null。

 运用第一题中的方法能成功找到mid结点,然后成功反转后是这样的。

 这是就可以创建循环,然后head和l2的值相互比较,如果有一个不相同那么直接返回false,判断相同过后,head和l2继续向后移动,比较下一个。直到循环退出,则证明该链表是回文链表,返回true。

    public boolean isPalindrome(ListNode head) {
        ListNode mid = middleNode(head);
        ListNode l2 = reverseList(mid);
        while (l2 != null) {
            if (head.val != l2.val) {
                return false;
            }
            head = head.next;
            l2 = l2.next;
        }
        return true;
    }
    public ListNode middleNode(ListNode head) {
       ListNode low = head;
       ListNode fast = head;
       while(fast != null && fast.next != null){
           fast = fast.next.next;
           low = low.next;
       }
    return low;
    }
    public ListNode reverseList(ListNode head) {
        if (head == null || head.next == null) {
            return head;
        }
        ListNode prev = null;
        ListNode cur = head;
        while (cur != null) {
            ListNode next = cur.next;
            cur.next = prev;
            prev = cur;
            cur = next;
        }
        return prev;
    }

三、链表中倒数第K个结点

输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。

例如,一个链表有5个节点,从头节点开始,它们的值依次是1、2、3 、4、5,这个链表的倒数第2个节点是值为4的节点。

有了快慢指针的定义,我们可以先让sec走k步,然后prev和sec一起向前走,当sec为空了,prev当前的值就是倒数第k个结点了。

 刚开始时,prev和sec都在head的位置上,进入while循环中,当i<k时,只有sec可以向后移动。

当i==k时,sec已经比prev先走了k步,所以sec和prev都可以向后移动了。

 当sec走到最后时,sec==null,所以整个循环跳出,这就是循环的终止条件,这个时候的prev结点就是倒数第k个结点。

    public ListNode getKthFromEnd(ListNode head, int k) {
        ListNode prev = head;
        ListNode sec = head;
        int i = 0;
        while(sec!=null){
            if(i>=k){
                prev = prev.next;
            }
            i++;
            sec = sec.next;
        }
        return prev;
    }

四、删除链表的倒数第n个结点 

给定一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

这种情况就不能找到倒数第n个结点,要找到它的前驱结点。然后进行删除操作。所以这道题就是前驱结点+删除节点问题,所以我们需要自己创造一个前驱结点,node和prev都指向这个前驱结点,x也指向,最终由x来输出连链表。

 有了第三道题,这道题就很好解决了,这道题只需要让prev比node多走n+1步即可。

 

 当prev已经多走了n+1步时,node也可以开始走了,两者一起继续向前进直到prev==null。

 

 这时prev已经为空了,node就是倒数第n个结点的前驱结点,这时只需要让node.next = node.next.next,就成功删除需要删除的结点了。但是有个特殊情况那就是node.next还是head没有进入循环,这时如果直接将按照正常思路,那么还是不能删除第一个元素,所以需要排除这种情况直接让x.next = node.next.next,最后返回x。

public ListNode removeNthFromEnd(ListNode head, int n) {
ListNode prev = new ListNode(-1);
        ListNode node = new ListNode(-1);
        ListNode x = new ListNode(-1);
        x.next = head;
        prev.next = head;
        node.next = head;
        int i = 0;
        while(prev!=null){
            if(i>n){
                node = node.next;
            }
            i++;
            prev = prev.next;
        }
        if(node.next == head){
            x.next = node.next.next;
        }else{
            node.next = node.next.next;
        }
        return x.next;
    }

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

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

相关文章

【MySQL】测试题03

文章目录1、创建数据库2、使用数据库3、创建数据表【3.1】创建学生信息表Student【3.2】创建课程信息表Course【3.3】创建教师信息表Teacher【3.4】创建成绩信息表Score4、添加数据【4.1】向学生student表添加数据【4.2】向课程course表添加数据【4.3】向教师信息teacher表添加…

【动手学深度学习】softmax回归的从零开始实现(PyTorch版本)(含源代码)

目录&#xff1a;softmax回归的从零开始实现一、理论基础1.1 前言1.2 分类问题1.3 网络架构1.4 全连接层的参数开销1.5 softmax运算1.6 小批量样本的矢量化1.7 损失函数1.7.1 对数似然1.7.2 softmax及其导数1.7.3 交叉熵损失1.8 信息论基础1.8.1 熵1.8.2 信息量1.8.3 重新审视交…

19 02-检索满足客户端定义的状态掩码的DTC列表

诊断协议那些事儿 诊断协议那些事儿专栏系列文章&#xff0c;19服务作为UDS中子功能最多的服务&#xff0c;一共有28种子功能&#xff0c;本文将介绍常用的19 02服务&#xff1a;根据状态掩码读取DTC列表。 关联文章&#xff1a; 19服务List 19 01-通过状态掩码读取DTC数目 …

详细教程。2022年滁州市明光市、来安县等各地区高新技术企业申报

安徽省大力鼓励企业申报高新技术企业&#xff0c;于高企申报也有很多奖补。滁州市企业申报奖补政策发布&#xff0c;企业可以根据自身情况申请奖补&#xff0c;奖补金额为10万元至30万元不等&#xff0c;明光市&#xff0c;凤阳县等各地区奖补申请可以通过市级机关办理。 下面小…

跟艾文学编程《Python数据可视化》(01)基于Plotly的动态可视化绘图

作者&#xff1a;艾文&#xff0c;计算机硕士学位&#xff0c;企业内训讲师和金牌面试官&#xff0c;公司资深算法专家&#xff0c;现就职BAT一线大厂。邮箱&#xff1a;1121025745qq.com博客&#xff1a;https://wenjie.blog.csdn.net/内容&#xff1a;跟艾文学编程《Python数…

2022-11-21 mysql列存储引擎-架构实现缺陷梳理-P2

摘要: 收集现有代码的糟糕实现&#xff0c;前事不忘后事之师&#xff0c;把这些烂东西定死在耻辱柱上以免再次发生 糟糕的设计: 一. DGMaterializedIterator::GetNextPackrow 函数实现: int DimensionGroupMaterialized::DGMaterializedIterator::GetNextPackrow(int dim, int…

【Linux系统】第一篇:基础指令篇

文章目录一、Linux中的文件二、Linux用户三、Linux基本指令ls指令pwd命令cd指令touch指令mkdir指令rmdir指令rm 指令man指令cp指令mv指令cat指令tac指令more指令less指令head指令tail指令管道重定向date指令cal指令find指令which指令alias指令whereis指令grep指令wc指令sort指令…

Node的web编程(二)

一、JSON数据 1、定义 JavaScript Object Notation&#xff0c;是一种轻量级的前后端数据交换的格式(数据格式)。 2、特点 &#xff08;1&#xff09;容易阅读和编写 &#xff08;2&#xff09;语言无关性 &#xff08;3&#xff09;便于编译、解析 3、语法要求 &#…

Mac m1配置flutter开发环境

Mac m1配置flutter开发环境 文章目录Mac m1配置flutter开发环境一、下载Android Studio二、下载flutter sdk三、新建flutter project四、使用在线环境进行Flutter开发Dart在线运行环境Flutter在线运行环境一、下载Android Studio 进入官网下载&#xff0c;选择苹果芯片版本。 …

【Spring(三)】熟练掌握Spring的使用

有关Spring的所有文章都收录于我的专栏&#xff1a;&#x1f449;Spring&#x1f448; 目录 一、前言 二、通过静态工厂获取对象 三、通过实例工厂获取对象 四、通过FactoryBean获取对象 五、Bean配置信息重用 六、Bean创建顺序 七、Bean对象的单例和多例 八、Bean的生命周期 九…

Weblogic SSRF 漏洞(CVE-2014-4210)分析

Weblogic SSRF 漏洞是一个比较经典的SSRF 漏洞案例&#xff0c;该漏洞存在于 http://127.0.0.1:7001/uddiexplorer/SearchPublicRegistries. jsp 页面中&#xff0c;如图 1-1 所示图 1-1 Weblogic SSRF 漏洞Weblogic SSRF 漏洞可以通过向服务端发送以下请求参数进行触发&#x…

ARFoundation系列讲解 - 70 HumanBodyTracking3D

---------------------------------------------- 视频教程来源于网络,侵权必删! --------------------------------------------- 一、简介 HumanBodyTracking3D(身体跟踪3D)案例,当设备检查到人体时,会返回检测到人体关节点的3D空间位置(需要在iOS 13或更高版本的A12…

瞪羚优化算法(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

Java集合类——ArrayList(扩容机制)

线性表 线性表是n个相同类型元素的有限序列&#xff0c;逻辑上连续物理上不一定是连续的&#xff0c;存储结构上分为顺序存储和链式存储&#xff0c;常见的线性表有&#xff1a;顺序表&#xff0c;链表&#xff0c;栈&#xff0c;队列…… ArrayList 数据结构 ArrayList&am…

赋值运算符重载,取地址及const取地址操作符重载

赋值运算符重载1.运算符重载2.赋值运算符重载3.取地址及const取地址操作符重载如果一个类中什么成员都没有&#xff0c;那么该类简称为空类。而空类中其实并不是真的什么都没有&#xff0c;任何类在什么都不写时&#xff0c;编译器会自动生成以下6个默认成员函数。构造函数&…

同花顺_代码解析_技术指标_V,W

本文通过对同花顺中现成代码进行解析&#xff0c;用以了解同花顺相关策略设计的思想 目录 V&R VMA VMACD VOSC VPT VR VRFS VRSI VSTD W&R WVAD V&R 波动区间 用来衡量该股的市场波动风险.即95%的概率波动区间. 行号 1 n -> 250 2 x -> 收…

【考研英语语法】状语从句精讲

一、状语从句概述 &#xff08;一&#xff09;状语从句的含义 状语从句&#xff0c;指的就是一个句子作状语&#xff0c;表达“描述性的信息”&#xff0c;补充说明另一个句子&#xff08;主句&#xff09;。描述性的信息有很多种&#xff0c;可以描述时间、地点、原因、结果…

Web大学生网页成品HTML+CSS音乐吧 7页

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材&#xff0c;DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 音乐网页设计 | 仿网易云音乐 | 各大音乐官网网页 | 明星音乐演唱会主题 | 爵士乐音乐 | 民族音乐 | 等网站的设计与制作 | HTML期末大学生网页设计作…

Django开发笔记

Django开发笔记Django学习1. Django安装path()函数2. 创建项目2.1 终端命令创建2.2 pycharm创建项目3. App4. 创建页面4.1 再写一个页面4.2 模板---Templates4.3 静态文件4.3.1 创建static目录4.3.2 静态文件的引用5. 模板语法案例&#xff1a;伪联通新闻中心6. 请求和响应案例…

KT148A语音芯片按键版本一对一触发播放常见的问题集锦FAQ_V4

1.1 有3个IO&#xff0c;都是一样的功能吗&#xff1f;从配置文件的说明来看&#xff0c;功能是键控发声&#xff0c;那么3个IO都只能是键控发声吗&#xff1f;还是可以有选择地某个IO对应播放那段语音&#xff1f;三个按键有什么区别&#xff1f;他们和语音号是如何对应的&…