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;
    }
相关推荐
无敌最俊朗@几秒前
Qt 多线程编程: moveToThread 模式讲解
java·开发语言
埃伊蟹黄面13 分钟前
模拟算法思想
c++·算法·leetcode
副露のmagic19 分钟前
更弱智的算法学习day 10
python·学习·算法
hweiyu0021 分钟前
数据结构:邻接矩阵
数据结构
程序员清风24 分钟前
别卷模型了!上下文工程才是大模型应用的王道!
java·后端·面试
go__Ahead26 分钟前
【Java】ThreadLocal源码解析
java
逸风尊者28 分钟前
开发可掌握的知识:uber H3网格
后端·算法
利剑 -~29 分钟前
Spring AI Alibaba 1.1版本
java·人工智能·spring
雨中飘荡的记忆31 分钟前
Guava工具库实战
java
while(1){yan}36 分钟前
JAVA中如何操作文件
java·开发语言·面试