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;
    }
相关推荐
冷雨夜中漫步11 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
北顾笙98011 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_6294947311 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
直奔標竿11 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
xin_nai11 小时前
LeetCode热题100(Java)(5)普通数组
算法·leetcode·职场和发展
旖-旎11 小时前
深搜练习(组合)(5)
c++·算法·深度优先·力扣
@小码农11 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
one_love_zfl11 小时前
java面试-微服务组件篇
java·微服务·面试
一只大袋鼠11 小时前
Java进阶:CGLIB动态代理解析
java·开发语言
环流_12 小时前
HTTP 协议的基本格式
java·网络协议·http