LeetCode 876. 链表的中间结点

题目描述:

给你单链表的头结点 head ,请你找出并返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点。

示例 1:

复制代码
输入:head = [1,2,3,4,5]
输出:[3,4,5]
解释:链表只有一个中间结点,值为 3 。

示例 2:

复制代码
输入:head = [1,2,3,4,5,6]
输出:[4,5,6]
解释:该链表有两个中间结点,值分别为 3 和 4 ,返回第二个结点。

代码:

复制代码
//奇数:p1走一步,p2走两步,p2.next!=null
    //偶数:p1走一步,p2走两步,p2!=null
    public ListNode middleNode(ListNode head){
        ListNode p1=head;
        ListNode p2=head;
        while(p2!=null&&p2.next!=null){//偶数:p2!=null(短路运算符写在前面,奇数:p2.next!=null
            p1=p1.next;
            p2=p2.next.next;
        }
        return p1;
    }
相关推荐
做cv的小昊7 分钟前
【TJU】研究生应用统计学课程笔记(8)——第四章 线性模型(4.1 一元线性回归分析)
笔记·线性代数·算法·数学建模·回归·线性回归·概率论
DFT计算杂谈8 分钟前
自动化脚本一键绘制三元化合物相图
java·运维·服务器·开发语言·前端·python·自动化
2301_7717172119 分钟前
Spring Boot 自动配置核心注解
java·spring boot·mybatis
小Y._21 分钟前
面试被问synchronized锁升级,这5个问题答不上来直接挂!
java
姚青&32 分钟前
测试技术体系
java·python
贾斯汀玛尔斯37 分钟前
每天学一个算法--倒排索引(Inverted Index)
算法·inverted-index
小e说说41 分钟前
打破偏科困境:这些学习软件助孩子重燃学习热情
算法
南境十里·墨染春水1 小时前
C++日志 2——实现单线程日志系统
java·jvm·c++
布吉岛的石头1 小时前
微服务网关统一鉴权、限流、日志实战
java·spring·微服务