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;
    }
相关推荐
RInk7oBjo1 天前
spring boot3--自动配置与手动配置
java·spring boot·后端
最初的↘那颗心1 天前
LangChain4j核心能力:AiService、Prompt注解与结构化输出实战
java·大模型·结构化输出·langchain4j·aiservice
lixia0417mul21 天前
简单的RAG知识库问答
java
云烟成雨TD1 天前
Spring AI 1.x 系列【25】结构化输出案例演示
java·人工智能·spring
鱼鳞_1 天前
Java学习笔记_Day23(HashMap)
java·笔记·学习
hua_ban_yu1 天前
新版本 idea 如何设置热部署
java·ide·intellij-idea
穿条秋裤到处跑1 天前
每日一道leetcode(2026.04.07):模拟行走机器人 II
leetcode·机器人
odng1 天前
拉取最新代码报错修复说明
java
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.04.07 题目:2069.模拟行走机器人二
笔记·leetcode·机器人