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;
    }
相关推荐
txxzjmzlh1 天前
Thread 类的基本用法
java·开发语言
好家伙VCC1 天前
**基于RISC-V架构的嵌入式系统开发:从零开始构建高效低功耗应用**在当前物联网(IoT)和边缘计
java·python·物联网·架构·risc-v
wyu729611 天前
Spring框架学习笔记:从IoC到声明式事务
java
会编程的土豆1 天前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论
qqacj1 天前
Spring Security 官网文档学习
java·学习·spring
阿洛学长1 天前
汉洛塔结构思维
算法
木子n11 天前
第2篇:坐标变换与数学基础:FOC算法的核心数学工具
算法·电机控制·foc
Rsun045511 天前
10、Java 桥接模式从入门到实战
java·开发语言·桥接模式
金銀銅鐵1 天前
[Java] 从 class 文件看 cglib 对 MethodInterceptor 的处理 (下)
java·后端
lee_curry1 天前
Java中关于“锁”的那些事
java·线程·并发·juc