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;
    }
相关推荐
LG.YDX3 分钟前
java: 题目:银行账户管理系统
java·开发语言·python
西建大的开心崽4 分钟前
疯狂Java讲义——第4章 流程控制与数组
java·开发语言
梦城忆8 分钟前
Java中的语法糖
java·windows·python
东方巴黎~Sunsiny12 分钟前
优雅的遍历JSONArray,获取里面的数据
java·json
_GR13 分钟前
每日OJ题_牛客_最长公共子序列_DP_C++_Java
java·开发语言·数据结构·c++·算法·leetcode
2401_8576100339 分钟前
Spring Boot技术在导师双选系统中的应用
java·数据库·spring boot
hello_syz1 小时前
lock4j 不生效的问题(个人原因导致的)
java·spring boot·spring·log4j
ZShiJ1 小时前
【题解】—— LeetCode一周小结44
算法·leetcode·职场和发展
祁思妙想1 小时前
7.《双指针篇》---⑦三数之和(中等偏难)
数据结构·算法·leetcode
祁思妙想1 小时前
6.《双指针篇》---⑥和为S的两个数字(中等但简单)(牛客)
java·数据结构·算法