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;
    }
相关推荐
_阿伟_几秒前
计算机知识科普
java·开发语言
ulias2121 分钟前
深挖进程间通信的奥秘
java·linux·服务器·开发语言·c++·算法
8Qi83 分钟前
LeetCode 62 & 63:不同路径 I & II(含障碍物)
java·算法·leetcode·职场和发展·动态规划
于先生吖4 分钟前
UniApp搭配Java后端实现到店预约上门指派,订单状态流转与结算开发教程
java·开发语言·uni-app
西安邮电大学4 分钟前
binlog/redolog/undolog三者对比
java·后端·其他·面试
城事漫游Molly6 分钟前
AI赋能质性研究(八): 断言与命题写作,实现从数据到理论跨越的5个高质量 Prompt
人工智能·算法·prompt·ai for science·定性研究
森林古猿16 分钟前
论CDQ分治
c++·学习·算法·排序算法
luj_17689 分钟前
局部两极分析破解数学建模难题
服务器·c语言·开发语言·经验分享·算法
CQU_JIAKE14 分钟前
6.4aaaa
算法
布朗克16821 分钟前
17 常用工具类
java·开发语言·工具类