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;
    }
相关推荐
mit6.824几秒前
中位数贪心|前缀和_距离和ret=l+r_1
算法
一匹电信狗1 分钟前
【LeetCode】栈和队列进阶题目
c++·算法·leetcode·职场和发展·stl·栈和队列
机器学习之心3 分钟前
198种组合算法+优化TCN时间卷积神经网络+SHAP分析+新数据预测+多输出!深度学习可解释分析,强烈安利,粉丝必备!
深度学习·算法·shap分析·tcn时间卷积神经网络
代码游侠4 分钟前
数据结构——线性表
linux·c语言·数据结构·学习·算法
潼心1412o5 分钟前
数据结构(长期更新)第10讲:堆
数据结构
吃着火锅x唱着歌6 分钟前
LeetCode 3371.识别数组中的最大异常值
数据结构·算法·leetcode
元亓亓亓9 分钟前
LeetCode热题100--74. 搜索二维矩阵--中等
算法·leetcode·矩阵
执笔论英雄9 分钟前
【RL】async原理
java·服务器·前端
z***948410 分钟前
Java进阶07 嵌套类
java·开发语言·python
dringlestry10 分钟前
B树的最大/最小高度
数据结构·b树