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;
    }
相关推荐
@SmartSi几秒前
AgentScope Java 入门系列:Spring AI Alibaba 与 AgentScope 的定位与区别
java·spring·agentscope
一只大袋鼠1 分钟前
JavaWeb四种文件上传方式(上篇)
java·开发语言·servlet·javaweb
网络工程小王1 分钟前
【LangGraph的工作流编排能力】学习笔记
java·服务器·数据库·人工智能·langchain
qingy_20463 分钟前
Redis Zset 底层数据结构及其使用场景
数据结构·数据库·redis
Lazionr4 分钟前
数据结构堆详解:原理、实现与应用
数据结构·算法
她说可以呀7 分钟前
JWT令牌检验用户是否登录
java·spring boot·spring·java-ee·maven
Zephyr_08 分钟前
c++数据结构
数据结构·c++
故事和你919 分钟前
蓝桥杯-2026年C++B组省赛
开发语言·数据结构·c++·算法·蓝桥杯·动态规划·图论
一氧化二氢.h9 分钟前
【简单理解】数组、数组列表、集合
java
哆啦A梦158810 分钟前
11,Springboot3+vue3个人中心,修改密码
java·前端·javascript·数据库·vue3