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;
    }
相关推荐
失重外太空啦1 分钟前
Tomcat
java·服务器·tomcat
屎到临头想搅便2 分钟前
TOMCAT
java·tomcat
m0_531237177 分钟前
C语言-数组练习进阶
c语言·开发语言·算法
Sylvia33.18 分钟前
火星数据:解构斯诺克每一杆进攻背后的数字语言
java·前端·python·数据挖掘·数据分析
qq_4542450320 分钟前
基于组件与行为的树状节点系统
数据结构·c#
超级大福宝21 分钟前
N皇后问题:经典回溯算法的一些分析
数据结构·c++·算法·leetcode
糖猫猫_27 分钟前
Kite:两种方式实现动态表名
java·后端
用户83071968408227 分钟前
5种Java字符串匹配方案深度对比,附性能测试和决策树
java
孤独风雪33 分钟前
Spring Stomp 消息使用
java·后端