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;
    }
相关推荐
minji...几秒前
Linux 多线程(四)线程等待,线程分离,线程管理,C++多线程,pthread库
linux·运维·开发语言·网络·c++·算法
sinat_255487817 分钟前
泛型·学习笔记
java·jvm·数据库·windows·python
H_BB7 分钟前
DFS实现回溯算法
数据结构·c++·算法·深度优先
汀、人工智能8 分钟前
[特殊字符] 第17课:滑动窗口最大值
数据结构·算法·数据库架构·图论·bfs·滑动窗口最大值
QuZero11 分钟前
Java Synchronized principle
java·开发语言
sheeta199814 分钟前
LeetCode 每日一题笔记 日期:2025.04.06 题目:874. 模拟行走机器人
笔记·leetcode·机器人
明灯伴古佛15 分钟前
面试:Java中乐观锁的实现原理是什么
java·面试·职场和发展
XiYang-DING18 分钟前
【LeetCode】232. 用栈实现队列
算法·leetcode·职场和发展
人道领域19 分钟前
【LeetCode刷题日记】142.环形链表Ⅱ
算法·leetcode·链表
SimonKing19 分钟前
白嫖党狂喜!魔塔社区每天2000次免费大模型调用,真香!
java·后端·程序员